1
0
mirror of https://github.com/goreleaser/goreleaser.git synced 2025-01-24 04:16:27 +02:00

137 lines
3.4 KiB
Go
Raw Normal View History

2017-04-14 15:39:32 -03:00
// Package fpm implements the Pipe interface providing FPM bindings.
2017-01-29 21:55:32 -02:00
package fpm
import (
"errors"
2017-06-27 19:36:36 -03:00
"fmt"
2017-01-29 21:55:32 -02:00
"os/exec"
"path/filepath"
2017-07-01 12:58:48 -03:00
"strings"
2017-01-29 21:55:32 -02:00
2017-06-22 00:09:14 -03:00
"github.com/apex/log"
2017-01-29 21:55:32 -02:00
"github.com/goreleaser/goreleaser/context"
2017-01-29 22:01:26 -02:00
"golang.org/x/sync/errgroup"
2017-01-29 21:55:32 -02:00
)
// ErrNoFPM is shown when fpm cannot be found in $PATH
var ErrNoFPM = errors.New("fpm not present in $PATH")
// Pipe for fpm packaging
type Pipe struct{}
// Description of the pipe
func (Pipe) Description() string {
return "Creating Linux packages with fpm"
}
// Run the pipe
func (Pipe) Run(ctx *context.Context) error {
2017-01-29 22:01:26 -02:00
if len(ctx.Config.FPM.Formats) == 0 {
2017-08-17 18:41:08 -03:00
log.Warn("skipping because no output formats configured")
2017-01-29 22:01:26 -02:00
return nil
}
2017-01-30 07:53:05 -02:00
_, err := exec.LookPath("fpm")
if err != nil {
2017-01-29 21:55:32 -02:00
return ErrNoFPM
}
2017-01-29 22:33:08 -02:00
2017-01-29 21:55:32 -02:00
var g errgroup.Group
for _, format := range ctx.Config.FPM.Formats {
for platform, groups := range ctx.Binaries {
if !strings.Contains(platform, "linux") {
log.WithField("platform", platform).Debug("skipped non-linux builds for fpm")
2017-01-29 21:55:32 -02:00
continue
}
2017-07-01 12:58:48 -03:00
format := format
arch := archFor(platform)
for folder, binaries := range groups {
g.Go(func() error {
return create(ctx, format, folder, arch, platform, binaries)
})
}
2017-01-29 21:55:32 -02:00
}
}
return g.Wait()
}
2017-07-01 12:58:48 -03:00
func archFor(key string) string {
if strings.Contains(key, "386") {
return "i386"
}
return "x86_64"
}
func create(ctx *context.Context, format, folder, arch, platform string, binaries []context.Binary) error {
2017-07-01 12:58:48 -03:00
var path = filepath.Join(ctx.Config.Dist, folder)
var file = path + "." + format
2017-07-01 12:58:48 -03:00
log.WithField("file", file).Info("creating fpm archive")
2017-01-29 21:55:32 -02:00
var options = []string{
2017-02-01 15:40:27 -02:00
"--input-type", "dir",
"--output-type", format,
2017-07-01 22:42:10 -03:00
"--name", ctx.Config.ProjectName,
2017-02-01 15:40:27 -02:00
"--version", ctx.Version,
"--architecture", arch,
// "--chdir", path,
2017-02-01 15:40:27 -02:00
"--package", file,
2017-01-29 21:55:32 -02:00
"--force",
}
2017-04-21 17:02:28 -03:00
if ctx.Config.FPM.Vendor != "" {
options = append(options, "--vendor", ctx.Config.FPM.Vendor)
}
2017-04-21 17:02:28 -03:00
if ctx.Config.FPM.Homepage != "" {
options = append(options, "--url", ctx.Config.FPM.Homepage)
}
2017-04-21 17:02:28 -03:00
if ctx.Config.FPM.Maintainer != "" {
options = append(options, "--maintainer", ctx.Config.FPM.Maintainer)
}
2017-04-21 17:02:28 -03:00
if ctx.Config.FPM.Description != "" {
options = append(options, "--description", ctx.Config.FPM.Description)
}
2017-04-21 17:02:28 -03:00
if ctx.Config.FPM.License != "" {
options = append(options, "--license", ctx.Config.FPM.License)
}
2017-01-29 22:33:08 -02:00
for _, dep := range ctx.Config.FPM.Dependencies {
2017-02-01 15:40:27 -02:00
options = append(options, "--depends", dep)
2017-01-29 21:55:32 -02:00
}
2017-02-01 15:40:27 -02:00
for _, conflict := range ctx.Config.FPM.Conflicts {
options = append(options, "--conflicts", conflict)
}
// FPM requires --rpm-os=linux if your rpm target is linux
if format == "rpm" && strings.Contains(platform, "linux") {
options = append(options, "--rpm-os", "linux")
}
for _, binary := range binaries {
2017-06-27 19:36:36 -03:00
// This basically tells fpm to put the binary in the /usr/local/bin
// binary=/usr/local/bin/binary
log.WithField("path", binary.Path).
WithField("name", binary.Name).
Info("passed binary to fpm")
2017-06-27 19:36:36 -03:00
options = append(options, fmt.Sprintf(
"%s=%s",
binary.Path,
filepath.Join("/usr/local/bin", binary.Name),
2017-06-27 19:36:36 -03:00
))
}
2017-01-29 22:33:08 -02:00
for src, dest := range ctx.Config.FPM.Files {
log.WithField("src", src).
WithField("dest", dest).
Info("passed extra file to fpm")
options = append(options, fmt.Sprintf(
"%s=%s",
src,
dest,
))
}
2017-02-01 15:40:27 -02:00
if out, err := exec.Command("fpm", options...).CombinedOutput(); err != nil {
2017-01-30 08:17:15 -02:00
return errors.New(string(out))
2017-01-29 21:55:32 -02:00
}
ctx.AddArtifact(file)
2017-01-29 21:55:32 -02:00
return nil
}