updated to v2 api
This commit is contained in:
28
main.go
28
main.go
@ -16,7 +16,7 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
manifestUrl = "https://updater.project-epoch.net/api/manifest"
|
manifestUrl = "https://updater.project-epoch.net/api/v2/manifest"
|
||||||
defaultWowPath = "/path/to/wow"
|
defaultWowPath = "/path/to/wow"
|
||||||
defaultLaunchCmd = "not configured"
|
defaultLaunchCmd = "not configured"
|
||||||
)
|
)
|
||||||
@ -125,18 +125,22 @@ func downloadUpdate(config *Config, force bool) (DownloadStats, error) {
|
|||||||
}
|
}
|
||||||
defer outFile.Close()
|
defer outFile.Close()
|
||||||
|
|
||||||
resp, err := http.Get(file.URL)
|
for _, url := range []string{file.Urls.Cloudflare, file.Urls.Digitalocean, file.Urls.None} {
|
||||||
if err != nil {
|
resp, err := http.Get(url)
|
||||||
return stats, err
|
if err != nil {
|
||||||
}
|
return stats, err
|
||||||
defer resp.Body.Close()
|
}
|
||||||
if resp.StatusCode != http.StatusOK {
|
defer resp.Body.Close()
|
||||||
return stats, fmt.Errorf("failed to download update from %s, status code: %d", file.URL, resp.StatusCode)
|
if resp.StatusCode != http.StatusOK {
|
||||||
}
|
return stats, fmt.Errorf("failed to download update from %s, status code: %d", url, resp.StatusCode)
|
||||||
|
}
|
||||||
|
|
||||||
_, err = io.Copy(outFile, resp.Body)
|
_, err = io.Copy(outFile, resp.Body)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return stats, err
|
return stats, err
|
||||||
|
}
|
||||||
|
|
||||||
|
break
|
||||||
}
|
}
|
||||||
|
|
||||||
stats.updated += 1
|
stats.updated += 1
|
||||||
|
13
manifest.go
13
manifest.go
@ -11,13 +11,18 @@ type File struct {
|
|||||||
Hash string `json:"Hash"`
|
Hash string `json:"Hash"`
|
||||||
Size int `json:"Size"`
|
Size int `json:"Size"`
|
||||||
Custom bool `json:"Custom"`
|
Custom bool `json:"Custom"`
|
||||||
URL string `json:"URL"`
|
Urls struct {
|
||||||
Origin string `json:"Origin"`
|
Digitalocean string `json:"digitalocean"`
|
||||||
|
Cloudflare string `json:"cloudflare"`
|
||||||
|
None string `json:"none"`
|
||||||
|
} `json:"Urls"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type Manifest struct {
|
type Manifest struct {
|
||||||
Version string `json:"Version"`
|
Version string `json:"Version"`
|
||||||
Files []File `json:"Files"`
|
UID string `json:"Uid"`
|
||||||
|
Files []File `json:"Files"`
|
||||||
|
CheckedAt string `json:"checked_at"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func getManifest() (*Manifest, error) {
|
func getManifest() (*Manifest, error) {
|
||||||
|
Reference in New Issue
Block a user