cli: Move ClientExport to cliutil
This commit is contained in:
parent
e66d5a0537
commit
b540d10b48
@ -3,14 +3,9 @@ package cli
|
|||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"context"
|
"context"
|
||||||
"encoding/json"
|
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
"io/ioutil"
|
|
||||||
"net/http"
|
|
||||||
"net/url"
|
|
||||||
"os"
|
"os"
|
||||||
"path"
|
|
||||||
"sort"
|
"sort"
|
||||||
"strings"
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
@ -29,8 +24,6 @@ import (
|
|||||||
"github.com/ipld/go-ipld-prime/traversal/selector/builder"
|
"github.com/ipld/go-ipld-prime/traversal/selector/builder"
|
||||||
selectorparse "github.com/ipld/go-ipld-prime/traversal/selector/parse"
|
selectorparse "github.com/ipld/go-ipld-prime/traversal/selector/parse"
|
||||||
textselector "github.com/ipld/go-ipld-selector-text-lite"
|
textselector "github.com/ipld/go-ipld-selector-text-lite"
|
||||||
"github.com/multiformats/go-multiaddr"
|
|
||||||
manet "github.com/multiformats/go-multiaddr/net"
|
|
||||||
"github.com/urfave/cli/v2"
|
"github.com/urfave/cli/v2"
|
||||||
"golang.org/x/xerrors"
|
"golang.org/x/xerrors"
|
||||||
|
|
||||||
@ -40,6 +33,7 @@ import (
|
|||||||
|
|
||||||
lapi "github.com/filecoin-project/lotus/api"
|
lapi "github.com/filecoin-project/lotus/api"
|
||||||
"github.com/filecoin-project/lotus/chain/types"
|
"github.com/filecoin-project/lotus/chain/types"
|
||||||
|
cliutil "github.com/filecoin-project/lotus/cli/util"
|
||||||
"github.com/filecoin-project/lotus/markets/utils"
|
"github.com/filecoin-project/lotus/markets/utils"
|
||||||
"github.com/filecoin-project/lotus/node/repo"
|
"github.com/filecoin-project/lotus/node/repo"
|
||||||
)
|
)
|
||||||
@ -337,67 +331,6 @@ Examples:
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
func ApiAddrToUrl(apiAddr string) (*url.URL, error) {
|
|
||||||
ma, err := multiaddr.NewMultiaddr(apiAddr)
|
|
||||||
if err == nil {
|
|
||||||
_, addr, err := manet.DialArgs(ma)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
// todo: make cliutil helpers for this
|
|
||||||
apiAddr = "http://" + addr
|
|
||||||
}
|
|
||||||
aa, err := url.Parse(apiAddr)
|
|
||||||
if err != nil {
|
|
||||||
return nil, xerrors.Errorf("parsing api address: %w", err)
|
|
||||||
}
|
|
||||||
switch aa.Scheme {
|
|
||||||
case "ws":
|
|
||||||
aa.Scheme = "http"
|
|
||||||
case "wss":
|
|
||||||
aa.Scheme = "https"
|
|
||||||
}
|
|
||||||
|
|
||||||
return aa, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func ClientExportStream(apiAddr string, apiAuth http.Header, eref lapi.ExportRef, car bool) (io.ReadCloser, error) {
|
|
||||||
rj, err := json.Marshal(eref)
|
|
||||||
if err != nil {
|
|
||||||
return nil, xerrors.Errorf("marshaling export ref: %w", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
aa, err := ApiAddrToUrl(apiAddr)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
aa.Path = path.Join(aa.Path, "rest/v0/export")
|
|
||||||
req, err := http.NewRequest("GET", fmt.Sprintf("%s?car=%t&export=%s", aa, car, url.QueryEscape(string(rj))), nil)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
req.Header = apiAuth
|
|
||||||
|
|
||||||
resp, err := http.DefaultClient.Do(req)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
if resp.StatusCode != http.StatusOK {
|
|
||||||
em, err := ioutil.ReadAll(resp.Body)
|
|
||||||
if err != nil {
|
|
||||||
return nil, xerrors.Errorf("reading error body: %w", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
resp.Body.Close() // nolint
|
|
||||||
return nil, xerrors.Errorf("getting root car: http %d: %s", resp.StatusCode, string(em))
|
|
||||||
}
|
|
||||||
|
|
||||||
return resp.Body, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
var clientRetrieveCatCmd = &cli.Command{
|
var clientRetrieveCatCmd = &cli.Command{
|
||||||
Name: "cat",
|
Name: "cat",
|
||||||
Usage: "Show data from network",
|
Usage: "Show data from network",
|
||||||
@ -447,7 +380,7 @@ var clientRetrieveCatCmd = &cli.Command{
|
|||||||
eref.DAGs = append(eref.DAGs, lapi.DagSpec{DataSelector: &sel})
|
eref.DAGs = append(eref.DAGs, lapi.DagSpec{DataSelector: &sel})
|
||||||
}
|
}
|
||||||
|
|
||||||
rc, err := ClientExportStream(ainfo.Addr, ainfo.AuthHeader(), *eref, false)
|
rc, err := cliutil.ClientExportStream(ainfo.Addr, ainfo.AuthHeader(), *eref, false)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -535,7 +468,7 @@ var clientRetrieveLsCmd = &cli.Command{
|
|||||||
DataSelector: &dataSelector,
|
DataSelector: &dataSelector,
|
||||||
})
|
})
|
||||||
|
|
||||||
rc, err := ClientExportStream(ainfo.Addr, ainfo.AuthHeader(), *eref, true)
|
rc, err := cliutil.ClientExportStream(ainfo.Addr, ainfo.AuthHeader(), *eref, true)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return xerrors.Errorf("export: %w", err)
|
return xerrors.Errorf("export: %w", err)
|
||||||
}
|
}
|
||||||
|
78
cli/util/retrieval.go
Normal file
78
cli/util/retrieval.go
Normal file
@ -0,0 +1,78 @@
|
|||||||
|
package cliutil
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
"fmt"
|
||||||
|
"io"
|
||||||
|
"io/ioutil"
|
||||||
|
"net/http"
|
||||||
|
"net/url"
|
||||||
|
"path"
|
||||||
|
|
||||||
|
"github.com/multiformats/go-multiaddr"
|
||||||
|
manet "github.com/multiformats/go-multiaddr/net"
|
||||||
|
"golang.org/x/xerrors"
|
||||||
|
|
||||||
|
"github.com/filecoin-project/lotus/api"
|
||||||
|
)
|
||||||
|
|
||||||
|
func ApiAddrToUrl(apiAddr string) (*url.URL, error) {
|
||||||
|
ma, err := multiaddr.NewMultiaddr(apiAddr)
|
||||||
|
if err == nil {
|
||||||
|
_, addr, err := manet.DialArgs(ma)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
// todo: make cliutil helpers for this
|
||||||
|
apiAddr = "http://" + addr
|
||||||
|
}
|
||||||
|
aa, err := url.Parse(apiAddr)
|
||||||
|
if err != nil {
|
||||||
|
return nil, xerrors.Errorf("parsing api address: %w", err)
|
||||||
|
}
|
||||||
|
switch aa.Scheme {
|
||||||
|
case "ws":
|
||||||
|
aa.Scheme = "http"
|
||||||
|
case "wss":
|
||||||
|
aa.Scheme = "https"
|
||||||
|
}
|
||||||
|
|
||||||
|
return aa, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func ClientExportStream(apiAddr string, apiAuth http.Header, eref api.ExportRef, car bool) (io.ReadCloser, error) {
|
||||||
|
rj, err := json.Marshal(eref)
|
||||||
|
if err != nil {
|
||||||
|
return nil, xerrors.Errorf("marshaling export ref: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
aa, err := ApiAddrToUrl(apiAddr)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
aa.Path = path.Join(aa.Path, "rest/v0/export")
|
||||||
|
req, err := http.NewRequest("GET", fmt.Sprintf("%s?car=%t&export=%s", aa, car, url.QueryEscape(string(rj))), nil)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
req.Header = apiAuth
|
||||||
|
|
||||||
|
resp, err := http.DefaultClient.Do(req)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
if resp.StatusCode != http.StatusOK {
|
||||||
|
em, err := ioutil.ReadAll(resp.Body)
|
||||||
|
if err != nil {
|
||||||
|
return nil, xerrors.Errorf("reading error body: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
resp.Body.Close() // nolint
|
||||||
|
return nil, xerrors.Errorf("getting root car: http %d: %s", resp.StatusCode, string(em))
|
||||||
|
}
|
||||||
|
|
||||||
|
return resp.Body, nil
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user