|
@ -9,7 +9,6 @@ import ( |
|
|
"crypto/md5" |
|
|
"crypto/md5" |
|
|
"encoding/hex" |
|
|
"encoding/hex" |
|
|
"encoding/json" |
|
|
"encoding/json" |
|
|
"errors" |
|
|
|
|
|
"fmt" |
|
|
"fmt" |
|
|
"io" |
|
|
"io" |
|
|
"io/ioutil" |
|
|
"io/ioutil" |
|
@ -46,6 +45,13 @@ type Asset struct { |
|
|
URL string `json:"url"` |
|
|
URL string `json:"url"` |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
const githubAPITimeout = 30 * time.Second |
|
|
|
|
|
|
|
|
|
|
|
// githubError is returned by the GitHub API, e.g. for rate-limiting.
|
|
|
|
|
|
type githubError struct { |
|
|
|
|
|
Message string |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
var ( |
|
|
var ( |
|
|
updateOpt UpdateOptions |
|
|
updateOpt UpdateOptions |
|
|
) |
|
|
) |
|
@ -66,17 +72,6 @@ var cmdUpdate = &Command{ |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
func runUpdate(cmd *Command, args []string) bool { |
|
|
func runUpdate(cmd *Command, args []string) bool { |
|
|
weedPath := *updateOpt.Output |
|
|
|
|
|
if weedPath == "" { |
|
|
|
|
|
file, err := os.Executable() |
|
|
|
|
|
if err != nil { |
|
|
|
|
|
glog.Fatalf("unable to find executable:%s", err) |
|
|
|
|
|
return false |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
*updateOpt.Output = file |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
fi, err := os.Lstat(*updateOpt.Output) |
|
|
fi, err := os.Lstat(*updateOpt.Output) |
|
|
if err != nil { |
|
|
if err != nil { |
|
|
dirname := filepath.Dir(*updateOpt.Output) |
|
|
dirname := filepath.Dir(*updateOpt.Output) |
|
@ -91,7 +86,7 @@ func runUpdate(cmd *Command, args []string) bool { |
|
|
} |
|
|
} |
|
|
} else { |
|
|
} else { |
|
|
if !fi.Mode().IsRegular() { |
|
|
if !fi.Mode().IsRegular() { |
|
|
glog.Fatalf("output path %v is not a normal file, use --output to specify a different file path", updateOpt.Output) |
|
|
|
|
|
|
|
|
glog.Fatalf("output path %v is not a normal file, use --output to specify a different file path", *updateOpt.Output) |
|
|
return false |
|
|
return false |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
@ -111,11 +106,6 @@ func runUpdate(cmd *Command, args []string) bool { |
|
|
|
|
|
|
|
|
func downloadLatestStableRelease(ctx context.Context, target string) (version string, err error) { |
|
|
func downloadLatestStableRelease(ctx context.Context, target string) (version string, err error) { |
|
|
currentVersion := util.VERSION_NUMBER |
|
|
currentVersion := util.VERSION_NUMBER |
|
|
largeDiskSuffix := "" |
|
|
|
|
|
if util.VolumeSizeLimitGB == 8000 { |
|
|
|
|
|
largeDiskSuffix = "_large_disk" |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
rel, err := GitHubLatestRelease(ctx, "chrislusf", "seaweedfs") |
|
|
rel, err := GitHubLatestRelease(ctx, "chrislusf", "seaweedfs") |
|
|
if err != nil { |
|
|
if err != nil { |
|
|
return "", err |
|
|
return "", err |
|
@ -128,6 +118,11 @@ func downloadLatestStableRelease(ctx context.Context, target string) (version st |
|
|
|
|
|
|
|
|
glog.V(0).Infof("latest version is %v\n", rel.Version) |
|
|
glog.V(0).Infof("latest version is %v\n", rel.Version) |
|
|
|
|
|
|
|
|
|
|
|
largeDiskSuffix := "" |
|
|
|
|
|
if util.VolumeSizeLimitGB == 8000 { |
|
|
|
|
|
largeDiskSuffix = "_large_disk" |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
ext := "tar.gz" |
|
|
ext := "tar.gz" |
|
|
if runtime.GOOS == "windows" { |
|
|
if runtime.GOOS == "windows" { |
|
|
ext = "zip" |
|
|
ext = "zip" |
|
@ -150,7 +145,7 @@ func downloadLatestStableRelease(ctx context.Context, target string) (version st |
|
|
binaryMd5 := md5Ctx.Sum(nil) |
|
|
binaryMd5 := md5Ctx.Sum(nil) |
|
|
if hex.EncodeToString(binaryMd5) != string(md5Val[0:32]) { |
|
|
if hex.EncodeToString(binaryMd5) != string(md5Val[0:32]) { |
|
|
glog.Errorf("md5:'%s' '%s'", hex.EncodeToString(binaryMd5), string(md5Val[0:32])) |
|
|
glog.Errorf("md5:'%s' '%s'", hex.EncodeToString(binaryMd5), string(md5Val[0:32])) |
|
|
err = errors.New("binary md5sum doesn't match") |
|
|
|
|
|
|
|
|
err = fmt.Errorf("binary md5sum doesn't match") |
|
|
return "", err |
|
|
return "", err |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -169,13 +164,6 @@ func (r Release) String() string { |
|
|
len(r.Assets)) |
|
|
len(r.Assets)) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
const githubAPITimeout = 30 * time.Second |
|
|
|
|
|
|
|
|
|
|
|
// githubError is returned by the GitHub API, e.g. for rate-limiting.
|
|
|
|
|
|
type githubError struct { |
|
|
|
|
|
Message string |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// GitHubLatestRelease uses the GitHub API to get information about the latest
|
|
|
// GitHubLatestRelease uses the GitHub API to get information about the latest
|
|
|
// release of a repository.
|
|
|
// release of a repository.
|
|
|
func GitHubLatestRelease(ctx context.Context, owner, repo string) (Release, error) { |
|
|
func GitHubLatestRelease(ctx context.Context, owner, repo string) (Release, error) { |
|
@ -229,7 +217,7 @@ func GitHubLatestRelease(ctx context.Context, owner, repo string) (Release, erro |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
if release.TagName == "" { |
|
|
if release.TagName == "" { |
|
|
return Release{}, errors.New("tag name for latest release is empty") |
|
|
|
|
|
|
|
|
return Release{}, fmt.Errorf("tag name for latest release is empty") |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
release.Version = release.TagName |
|
|
release.Version = release.TagName |
|
@ -316,7 +304,7 @@ func extractToFile(buf []byte, filename, target string) error { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
if len(zrd.File) != 1 { |
|
|
if len(zrd.File) != 1 { |
|
|
return errors.New("ZIP archive contains more than one file") |
|
|
|
|
|
|
|
|
return fmt.Errorf("ZIP archive contains more than one file") |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
file, err := zrd.File[0].Open() |
|
|
file, err := zrd.File[0].Open() |
|
|