mirror of
https://github.com/SAP/jenkins-library.git
synced 2025-01-16 05:16:08 +02:00
98e4e01635
* feat(cnbBuild): warn users when dockerConfigJSON is missing necessary credentials * Update cmd/cnbBuild.go Co-authored-by: Ralf Pannemans <ralf.pannemans@sap.com> * Update pkg/cnbutils/auth.go Co-authored-by: Ralf Pannemans <ralf.pannemans@sap.com> * fix linting --------- Co-authored-by: Ralf Pannemans <ralf.pannemans@sap.com>
61 lines
1.3 KiB
Go
61 lines
1.3 KiB
Go
package cmd
|
|
|
|
import (
|
|
"bytes"
|
|
"encoding/json"
|
|
|
|
"github.com/SAP/jenkins-library/pkg/log"
|
|
"github.com/SAP/jenkins-library/pkg/piperutils"
|
|
"github.com/SAP/jenkins-library/pkg/telemetry"
|
|
jsonpatch "github.com/evanphx/json-patch"
|
|
)
|
|
|
|
func jsonApplyPatch(config jsonApplyPatchOptions, telemetryData *telemetry.CustomData) {
|
|
err := runJsonApplyPatch(&config, &piperutils.Files{})
|
|
if err != nil {
|
|
log.Entry().WithError(err).Fatal("step execution failed")
|
|
}
|
|
}
|
|
|
|
func runJsonApplyPatch(config *jsonApplyPatchOptions, fileUtils piperutils.FileUtils) error {
|
|
schema, err := fileUtils.FileRead(config.Input)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
patchFile, err := fileUtils.FileRead(config.Patch)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
patcher, err := jsonpatch.DecodePatch(patchFile)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
patchedSchema, err := patcher.Apply(schema)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
formattedJson, err := formatJson(patchedSchema)
|
|
if err != nil {
|
|
// Ignore error and just use original result.
|
|
formattedJson = patchedSchema
|
|
}
|
|
|
|
err = fileUtils.FileWrite(config.Output, formattedJson, 0644)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func formatJson(input []byte) ([]byte, error) {
|
|
var output bytes.Buffer
|
|
err := json.Indent(&output, input, "", " ")
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return output.Bytes(), nil
|
|
}
|