graphql-engine/cli/plugins/download/fetch.go
Aravind Shankar bb63d7e60e
cli: allow managing actions (#3859)
Co-authored-by: Rishichandra Wawhal <rishichandra.wawhal@gmail.com>
Co-authored-by: Rikin Kachhia <54616969+rikinsk@users.noreply.github.com>
Co-authored-by: Aravind <aravindkp@outlook.in>
Co-authored-by: Anon Ray <ecthiender@users.noreply.github.com>
Co-authored-by: Shahidh K Muhammed <muhammedshahid.k@gmail.com>
2020-02-24 21:44:46 +05:30

56 lines
1.6 KiB
Go

// Copyright 2019 The Kubernetes Authors.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package download
import (
"io"
"net/http"
"os"
"github.com/pkg/errors"
)
// Fetcher is used to get files from a URI.
type Fetcher interface {
// Get gets the file and returns an stream to read the file.
Get(uri string) (io.ReadCloser, error)
}
var _ Fetcher = HTTPFetcher{}
// HTTPFetcher is used to get a file from a http:// or https:// schema path.
type HTTPFetcher struct{}
// Get gets the file and returns an stream to read the file.
func (HTTPFetcher) Get(uri string) (io.ReadCloser, error) {
resp, err := http.Get(uri)
if err != nil {
return nil, errors.Wrapf(err, "failed to download %q", uri)
}
return resp.Body, nil
}
var _ Fetcher = fileFetcher{}
type fileFetcher struct{ f string }
func (f fileFetcher) Get(_ string) (io.ReadCloser, error) {
file, err := os.Open(f.f)
return file, errors.Wrapf(err, "failed to open archive file %q for reading", f.f)
}
// NewFileFetcher returns a local file reader.
func NewFileFetcher(path string) Fetcher { return fileFetcher{f: path} }