aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorYarden Shoham <hrsi88@gmail.com>2023-02-18 15:54:22 +0200
committerGitHub <noreply@github.com>2023-02-18 21:54:22 +0800
commitb2e58edd74f8d9bb530335e9b1ee2e356d4dacb4 (patch)
treec643628c110b0c77781ae24f38d39aec1a745d3d
parent98b7714c3b2ee2109206327f774cd035e231fe64 (diff)
downloadgitea-b2e58edd74f8d9bb530335e9b1ee2e356d4dacb4.tar.gz
gitea-b2e58edd74f8d9bb530335e9b1ee2e356d4dacb4.zip
Notify on container image create (#22806) (#22965)
Backport #22806 Fixes #22791 --------- Signed-off-by: Yarden Shoham <hrsi88@gmail.com> Co-authored-by: KN4CK3R <admin@oldschoolhack.me> Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com>
-rw-r--r--routers/api/packages/container/manifest.go26
1 files changed, 22 insertions, 4 deletions
diff --git a/routers/api/packages/container/manifest.go b/routers/api/packages/container/manifest.go
index dd5b650d0c..468cfd40a1 100644
--- a/routers/api/packages/container/manifest.go
+++ b/routers/api/packages/container/manifest.go
@@ -18,6 +18,7 @@ import (
user_model "code.gitea.io/gitea/models/user"
"code.gitea.io/gitea/modules/json"
"code.gitea.io/gitea/modules/log"
+ "code.gitea.io/gitea/modules/notification"
packages_module "code.gitea.io/gitea/modules/packages"
container_module "code.gitea.io/gitea/modules/packages/container"
"code.gitea.io/gitea/modules/util"
@@ -72,11 +73,9 @@ func processManifest(mci *manifestCreationInfo, buf *packages_module.HashedBuffe
}
if isImageManifestMediaType(mci.MediaType) {
- d, err := processImageManifest(mci, buf)
- return d, err
+ return processImageManifest(mci, buf)
} else if isImageIndexMediaType(mci.MediaType) {
- d, err := processImageManifestIndex(mci, buf)
- return d, err
+ return processImageManifestIndex(mci, buf)
}
return "", errManifestInvalid
}
@@ -183,6 +182,10 @@ func processImageManifest(mci *manifestCreationInfo, buf *packages_module.Hashed
return err
}
+ if err := notifyPackageCreate(mci.Creator, pv); err != nil {
+ return err
+ }
+
manifestDigest = digest
return nil
@@ -272,6 +275,10 @@ func processImageManifestIndex(mci *manifestCreationInfo, buf *packages_module.H
return err
}
+ if err := notifyPackageCreate(mci.Creator, pv); err != nil {
+ return err
+ }
+
manifestDigest = digest
return nil
@@ -283,6 +290,17 @@ func processImageManifestIndex(mci *manifestCreationInfo, buf *packages_module.H
return manifestDigest, nil
}
+func notifyPackageCreate(doer *user_model.User, pv *packages_model.PackageVersion) error {
+ pd, err := packages_model.GetPackageDescriptor(db.DefaultContext, pv)
+ if err != nil {
+ return err
+ }
+
+ notification.NotifyPackageCreate(doer, pd)
+
+ return nil
+}
+
func createPackageAndVersion(ctx context.Context, mci *manifestCreationInfo, metadata *container_module.Metadata) (*packages_model.PackageVersion, error) {
created := true
p := &packages_model.Package{