mirror of
https://github.com/kennethreitz/herald.git
synced 2026-06-05 23:00:19 +00:00
a280e9eb94
Signed-off-by: Kenneth Reitz <me@kennethreitz.org>
154 lines
3.5 KiB
Go
154 lines
3.5 KiB
Go
package herald
|
|
|
|
// import "os"
|
|
import "fmt"
|
|
import "github.com/hashicorp/go-getter"
|
|
import "github.com/garyburd/redigo/redis"
|
|
import "io/ioutil"
|
|
import "log"
|
|
import "path/filepath"
|
|
import "strings"
|
|
import "os"
|
|
import "os/exec"
|
|
|
|
// Buildpack Information.
|
|
const BP_BRANCH = "versions"
|
|
const BP_TARBALL_TEMPLATE = "https://github.com/heroku/heroku-buildpack-%s/archive/%s.zip"
|
|
var BUILDPACKS = []string { "python", "php", "nodejs", "ruby", "jvm-common" }
|
|
|
|
// Redis Stuff.
|
|
var REDIS_URL = os.Getenv("REDIS_URL")
|
|
|
|
// Connects to Redis instance, returns connection object.
|
|
func RedisConnect() redis.Conn {
|
|
c, err := redis.DialURL(REDIS_URL)
|
|
if err != nil {
|
|
// Fail epically.
|
|
log.Fatal(err)
|
|
}
|
|
defer c.Close()
|
|
|
|
return c
|
|
}
|
|
|
|
// TODO: Maybe remove.
|
|
type Version string
|
|
|
|
|
|
|
|
// A Buildpack, which seems inherintly useful for this utility.
|
|
type Buildpack struct{
|
|
Versions []Version
|
|
Tarball string
|
|
Path string
|
|
// ExecutablePath string
|
|
Name string
|
|
}
|
|
|
|
// An Executable, provided by a buildpack, for collecting version information.
|
|
type Executable struct{
|
|
Path string
|
|
}
|
|
|
|
// String representation of Executable.
|
|
func (e Executable) String() string {
|
|
sl := strings.Split(e.Path, "/")
|
|
return sl[len(sl) - 1]
|
|
}
|
|
|
|
// Ensures that the given executable is… executable.
|
|
func (e Executable) EnsureExecutable() {
|
|
// TODO: Chmod to the proper permissions.
|
|
if err := os.Chmod(e.Path, 0777); err != nil {
|
|
// TODO: return error, etc.
|
|
log.Fatal(err)
|
|
}
|
|
}
|
|
|
|
// Executes the given executable, and returns results.
|
|
func (e Executable) Execute() []string {
|
|
out, err := exec.Command(e.Path).Output()
|
|
if err != nil {
|
|
// TODO: Update this to return, etc.
|
|
log.Fatal(err)
|
|
}
|
|
return strings.Split(string(out), "\n")
|
|
|
|
}
|
|
|
|
// Returns the GitHub ZipBall URI for the given buildpack.
|
|
func (b Buildpack) ZipballURI() string {
|
|
return fmt.Sprintf(BP_TARBALL_TEMPLATE, b.Name, BP_BRANCH)
|
|
}
|
|
|
|
// Downloads the given buildpack to a temporary directory.
|
|
// Returns a new Buildpack object, as well as the target.
|
|
func (b *Buildpack) Download() string {
|
|
target, _ := ioutil.TempDir("", "buildpacks")
|
|
|
|
getter.Get(target, b.ZipballURI())
|
|
|
|
// The branch to base this off of.
|
|
|
|
// Set the Path.
|
|
b.Path = target + fmt.Sprintf("/heroku-buildpack-%s-%s", b.Name, BP_BRANCH)
|
|
|
|
return b.Path
|
|
|
|
}
|
|
|
|
// String representatino of Buildpack.
|
|
func (b Buildpack) String() string {
|
|
return b.Name
|
|
}
|
|
|
|
// Determines wether a given path is a file or not.
|
|
func isDirectory(path string) (bool, error) {
|
|
fileInfo, err := os.Stat(path)
|
|
return fileInfo.IsDir(), err
|
|
}
|
|
|
|
// Finds executables from a given buildpack, with globbing.
|
|
// Rerturns a slice of the Executable type.
|
|
func (b Buildpack) FindVersionScripts() []Executable {
|
|
results := []Executable{}
|
|
|
|
glob_results, _ := filepath.Glob(fmt.Sprintf("%s/versions/*", b.Path))
|
|
for _, result := range(glob_results) {
|
|
|
|
// Only yield a result if the glob result is a file.
|
|
is_directory, _ := isDirectory(result)
|
|
if ! is_directory {
|
|
results = append(results, NewExecutable(result))
|
|
}
|
|
|
|
}
|
|
|
|
return results
|
|
}
|
|
|
|
// Creates a new Executable type.
|
|
func NewExecutable(path string) Executable {
|
|
return Executable{
|
|
Path: path,
|
|
}
|
|
}
|
|
|
|
// Creates a new Buildpack type.
|
|
func NewBuildpack(name string) Buildpack {
|
|
return Buildpack{
|
|
Name: name,
|
|
}
|
|
}
|
|
|
|
// Generates a list of Buildpack objects, to be used by this utility.
|
|
func GetBuildpacks() []Buildpack {
|
|
// Download and unpack each Zipball from GitHub.
|
|
|
|
buildpacks := []Buildpack{}
|
|
for _, bp := range(BUILDPACKS) {
|
|
buildpacks = append(buildpacks, NewBuildpack(bp))
|
|
}
|
|
|
|
return buildpacks
|
|
} |