123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 |
- package main
- import (
- "fmt"
- "io"
- "net/http"
- "os"
- "os/exec"
- "strings"
- )
- func downloadFile(path string, url string) (err error) {
- // Create the file
- out, err := os.Create(path)
- if err != nil {
- return err
- }
- defer out.Close()
- // Get the data
- resp, err := http.Get(url)
- if err != nil {
- return err
- }
- defer resp.Body.Close()
- // Writer the body to file
- _, err = io.Copy(out, resp.Body)
- return err
- }
- // DownloadAndUnpack downloads url tgz and extracts to path.
- func downloadAndUnpack(url string, path string, trim bool) (err error) {
- err = os.MkdirAll(path, 0755)
- if err != nil {
- return
- }
- tokens := strings.Split(url, "/")
- fileName := tokens[len(tokens)-1]
- tarLocation := path + fileName
- defer os.Remove(tarLocation)
- err = downloadFile(tarLocation, url)
- if err != nil {
- return
- }
- if trim {
- err = exec.Command("/bin/sh", "-c",
- config.TarBin+" --strip-components 2 --include='*/"+fileName[:len(fileName)-7]+"/trunk/' -xf "+tarLocation+" -C "+path).Run()
- os.Rename(path+"trunk", path+fileName[:len(fileName)-7]) // kurwa
- } else {
- err = exec.Command(config.TarBin, "-xf", tarLocation, "-C", path).Run()
- }
- if err != nil {
- return
- }
- return
- }
- func getPkgbuilds(pkgs []string) error {
- //possibleAurs := make([]string, 0, 0)
- wd, err := os.Getwd()
- if err != nil {
- return err
- }
- wd = wd + "/"
- missing, err := getPkgbuildsfromABS(pkgs, wd)
- if err != nil {
- return err
- }
- err = getPkgbuildsfromAUR(missing, wd)
- return err
- }
- // GetPkgbuild downloads pkgbuild from the ABS.
- func getPkgbuildsfromABS(pkgs []string, path string) (missing []string, err error) {
- dbList, err := alpmHandle.SyncDbs()
- if err != nil {
- return
- }
- nextPkg:
- for _, pkgN := range pkgs {
- for _, db := range dbList.Slice() {
- pkg, err := db.PkgByName(pkgN)
- if err == nil {
- var url string
- if db.Name() == "core" || db.Name() == "extra" {
- url = "https://projects.archlinux.org/svntogit/packages.git/snapshot/packages/" + pkg.Base() + ".tar.gz"
- } else if db.Name() == "community" {
- url = "https://projects.archlinux.org/svntogit/community.git/snapshot/community-packages/" + pkg.Base() + ".tar.gz"
- } else {
- fmt.Println(pkgN + " not in standard repositories")
- }
- errD := downloadAndUnpack(url, path, true)
- if errD != nil {
- fmt.Println(bold(yellow(pkg.Name())), bold(green(errD.Error())))
- }
- fmt.Println(bold(green(arrow)), bold(green("Downloaded")), bold(yellow(pkg.Name())), bold(green("from ABS")))
- continue nextPkg
- }
- }
- missing = append(missing, pkgN)
- }
- return
- }
- // GetPkgbuild downloads pkgbuild from the AUR.
- func getPkgbuildsfromAUR(pkgs []string, dir string) (err error) {
- aq, err := aurInfo(pkgs)
- if err != nil {
- return err
- }
- for _, pkg := range aq {
- downloadAndUnpack(baseURL+aq[0].URLPath, dir, false)
- fmt.Println(bold(green(arrow)), bold(green("Downloaded")), bold(yellow(pkg.Name)), bold(green("from AUR")))
- }
- return
- }
|