|
|
@ -50,7 +50,7 @@ type manifestCreationInfo struct {
|
|
|
|
Properties map[string]string
|
|
|
|
Properties map[string]string
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
func processManifest(mci *manifestCreationInfo, buf *packages_module.HashedBuffer) (string, error) {
|
|
|
|
func processManifest(ctx context.Context, mci *manifestCreationInfo, buf *packages_module.HashedBuffer) (string, error) {
|
|
|
|
var index oci.Index
|
|
|
|
var index oci.Index
|
|
|
|
if err := json.NewDecoder(buf).Decode(&index); err != nil {
|
|
|
|
if err := json.NewDecoder(buf).Decode(&index); err != nil {
|
|
|
|
return "", err
|
|
|
|
return "", err
|
|
|
@ -72,14 +72,14 @@ func processManifest(mci *manifestCreationInfo, buf *packages_module.HashedBuffe
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if isImageManifestMediaType(mci.MediaType) {
|
|
|
|
if isImageManifestMediaType(mci.MediaType) {
|
|
|
|
return processImageManifest(mci, buf)
|
|
|
|
return processImageManifest(ctx, mci, buf)
|
|
|
|
} else if isImageIndexMediaType(mci.MediaType) {
|
|
|
|
} else if isImageIndexMediaType(mci.MediaType) {
|
|
|
|
return processImageManifestIndex(mci, buf)
|
|
|
|
return processImageManifestIndex(ctx, mci, buf)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return "", errManifestInvalid
|
|
|
|
return "", errManifestInvalid
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
func processImageManifest(mci *manifestCreationInfo, buf *packages_module.HashedBuffer) (string, error) {
|
|
|
|
func processImageManifest(ctx context.Context, mci *manifestCreationInfo, buf *packages_module.HashedBuffer) (string, error) {
|
|
|
|
manifestDigest := ""
|
|
|
|
manifestDigest := ""
|
|
|
|
|
|
|
|
|
|
|
|
err := func() error {
|
|
|
|
err := func() error {
|
|
|
@ -92,7 +92,7 @@ func processImageManifest(mci *manifestCreationInfo, buf *packages_module.Hashed
|
|
|
|
return err
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
ctx, committer, err := db.TxContext(db.DefaultContext)
|
|
|
|
ctx, committer, err := db.TxContext(ctx)
|
|
|
|
if err != nil {
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -181,7 +181,7 @@ func processImageManifest(mci *manifestCreationInfo, buf *packages_module.Hashed
|
|
|
|
return err
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if err := notifyPackageCreate(mci.Creator, pv); err != nil {
|
|
|
|
if err := notifyPackageCreate(ctx, mci.Creator, pv); err != nil {
|
|
|
|
return err
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -196,7 +196,7 @@ func processImageManifest(mci *manifestCreationInfo, buf *packages_module.Hashed
|
|
|
|
return manifestDigest, nil
|
|
|
|
return manifestDigest, nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
func processImageManifestIndex(mci *manifestCreationInfo, buf *packages_module.HashedBuffer) (string, error) {
|
|
|
|
func processImageManifestIndex(ctx context.Context, mci *manifestCreationInfo, buf *packages_module.HashedBuffer) (string, error) {
|
|
|
|
manifestDigest := ""
|
|
|
|
manifestDigest := ""
|
|
|
|
|
|
|
|
|
|
|
|
err := func() error {
|
|
|
|
err := func() error {
|
|
|
@ -209,7 +209,7 @@ func processImageManifestIndex(mci *manifestCreationInfo, buf *packages_module.H
|
|
|
|
return err
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
ctx, committer, err := db.TxContext(db.DefaultContext)
|
|
|
|
ctx, committer, err := db.TxContext(ctx)
|
|
|
|
if err != nil {
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -285,7 +285,7 @@ func processImageManifestIndex(mci *manifestCreationInfo, buf *packages_module.H
|
|
|
|
return err
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if err := notifyPackageCreate(mci.Creator, pv); err != nil {
|
|
|
|
if err := notifyPackageCreate(ctx, mci.Creator, pv); err != nil {
|
|
|
|
return err
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -300,13 +300,13 @@ func processImageManifestIndex(mci *manifestCreationInfo, buf *packages_module.H
|
|
|
|
return manifestDigest, nil
|
|
|
|
return manifestDigest, nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
func notifyPackageCreate(doer *user_model.User, pv *packages_model.PackageVersion) error {
|
|
|
|
func notifyPackageCreate(ctx context.Context, doer *user_model.User, pv *packages_model.PackageVersion) error {
|
|
|
|
pd, err := packages_model.GetPackageDescriptor(db.DefaultContext, pv)
|
|
|
|
pd, err := packages_model.GetPackageDescriptor(ctx, pv)
|
|
|
|
if err != nil {
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
notification.NotifyPackageCreate(db.DefaultContext, doer, pd)
|
|
|
|
notification.NotifyPackageCreate(ctx, doer, pd)
|
|
|
|
|
|
|
|
|
|
|
|
return nil
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|