|
@@ -32,6 +32,9 @@ func downloadFile(url string, destPath string) error {
|
|
|
return fmt.Errorf("bad http code %d for %s", resp.StatusCode, url)
|
|
|
}
|
|
|
|
|
|
+ // Download to a temporary location to avoid corrupting files
|
|
|
+ // that are currently in use or memory mapped.
|
|
|
+
|
|
|
tmpFile, err := os.CreateTemp(filepath.Dir(destPath), filepath.Base(destPath)+".*.tmp")
|
|
|
if err != nil {
|
|
|
return err
|
|
@@ -57,6 +60,11 @@ func downloadFile(url string, destPath string) error {
|
|
|
return err
|
|
|
}
|
|
|
|
|
|
+ // a check on stdout is used while scripting to know if the hub has been upgraded
|
|
|
+ // and a configuration reload is required
|
|
|
+ // TODO: use a better way to communicate this
|
|
|
+ fmt.Printf("updated %s\n", filepath.Base(destPath))
|
|
|
+
|
|
|
if err = os.Rename(tmpFileName, destPath); err != nil {
|
|
|
return err
|
|
|
}
|