main.go 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. package main
  2. import (
  3. "encoding/json"
  4. "net/http"
  5. "os"
  6. "path/filepath"
  7. "github.com/fatih/color"
  8. "github.com/google/go-containerregistry/pkg/authn"
  9. "github.com/google/go-containerregistry/pkg/name"
  10. "github.com/google/go-containerregistry/pkg/v1/remote"
  11. "github.com/google/go-containerregistry/pkg/v1/tarball"
  12. "github.com/sirupsen/logrus"
  13. resource "github.com/concourse/registry-image-resource"
  14. )
  15. type OutRequest struct {
  16. Source resource.Source `json:"source"`
  17. Params resource.PutParams `json:"params"`
  18. }
  19. type OutResponse struct {
  20. Version resource.Version `json:"version"`
  21. Metadata []resource.MetadataField `json:"metadata"`
  22. }
  23. func main() {
  24. logrus.SetOutput(os.Stderr)
  25. logrus.SetFormatter(&logrus.TextFormatter{
  26. ForceColors: true,
  27. })
  28. color.NoColor = false
  29. var req OutRequest
  30. decoder := json.NewDecoder(os.Stdin)
  31. decoder.DisallowUnknownFields()
  32. err := decoder.Decode(&req)
  33. if err != nil {
  34. logrus.Errorf("invalid payload: %s", err)
  35. os.Exit(1)
  36. return
  37. }
  38. if req.Source.Debug {
  39. logrus.SetLevel(logrus.DebugLevel)
  40. }
  41. if len(os.Args) < 2 {
  42. logrus.Errorf("destination path not specified")
  43. os.Exit(1)
  44. return
  45. }
  46. src := os.Args[1]
  47. ref := req.Source.Name()
  48. n, err := name.ParseReference(ref, name.WeakValidation)
  49. if err != nil {
  50. logrus.Errorf("could not resolve repository/tag reference: %s", err)
  51. os.Exit(1)
  52. return
  53. }
  54. imagePath := filepath.Join(src, req.Params.Image)
  55. img, err := tarball.ImageFromPath(imagePath, nil)
  56. if err != nil {
  57. logrus.Errorf("could not load image from path '%s': %s", req.Params.Image, err)
  58. os.Exit(1)
  59. return
  60. }
  61. digest, err := img.Digest()
  62. if err != nil {
  63. logrus.Errorf("failed to get image digest: %s", err)
  64. os.Exit(1)
  65. return
  66. }
  67. logrus.Infof("pushing %s to %s", digest, ref)
  68. auth := &authn.Basic{
  69. Username: req.Source.Username,
  70. Password: req.Source.Password,
  71. }
  72. err = remote.Write(n, img, auth, http.DefaultTransport)
  73. if err != nil {
  74. logrus.Errorf("failed to upload image: %s", err)
  75. os.Exit(1)
  76. return
  77. }
  78. logrus.Info("pushed")
  79. json.NewEncoder(os.Stdout).Encode(OutResponse{
  80. Version: resource.Version{
  81. Digest: digest.String(),
  82. },
  83. Metadata: []resource.MetadataField{},
  84. })
  85. }