mirror of
https://github.com/SAP/jenkins-library.git
synced 2025-01-18 05:18:24 +02:00
14c7feba1c
* Add CertificateDownload func to certutils package * Add customTlsCertificateLinks param for artifactPrepareVersion * Add the possibility to provide custom certs for artifactPrepareVersion * Update tests * Return back build flags * Return back build flags * Update pkg/certutils/certutils.go Apply suggestion from code review Co-authored-by: Christopher Fenner <26137398+CCFenner@users.noreply.github.com> --------- Co-authored-by: Christopher Fenner <26137398+CCFenner@users.noreply.github.com>
65 lines
1.7 KiB
Go
65 lines
1.7 KiB
Go
package certutils
|
|
|
|
import (
|
|
"io"
|
|
"net/http"
|
|
|
|
piperhttp "github.com/SAP/jenkins-library/pkg/http"
|
|
"github.com/SAP/jenkins-library/pkg/log"
|
|
"github.com/SAP/jenkins-library/pkg/piperutils"
|
|
"github.com/pkg/errors"
|
|
)
|
|
|
|
// CertificateUpdate adds certificates to the given truststore
|
|
func CertificateUpdate(certLinks []string, httpClient piperhttp.Sender, fileUtils piperutils.FileUtils, caCertsFile string) error {
|
|
// TODO this implementation doesn't work on non-linux machines, is not failsafe and should be implemented differently
|
|
|
|
if len(certLinks) == 0 {
|
|
return nil
|
|
}
|
|
|
|
caCerts, err := fileUtils.FileRead(caCertsFile)
|
|
if err != nil {
|
|
return errors.Wrapf(err, "failed to load file '%v'", caCertsFile)
|
|
}
|
|
|
|
byteCerts, err := CertificateDownload(certLinks, httpClient)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
caCerts = append(caCerts, byteCerts...)
|
|
|
|
err = fileUtils.FileWrite(caCertsFile, caCerts, 0644)
|
|
if err != nil {
|
|
return errors.Wrapf(err, "failed to update file '%v'", caCertsFile)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// CertificateDownload downloads certificates and returns them as a byte slice
|
|
func CertificateDownload(certLinks []string, client piperhttp.Sender) ([]byte, error) {
|
|
if len(certLinks) == 0 {
|
|
return nil, nil
|
|
}
|
|
|
|
var certs []byte
|
|
for _, certLink := range certLinks {
|
|
log.Entry().Debugf("Downloading CA certificate from URL: %s", certLink)
|
|
response, err := client.SendRequest(http.MethodGet, certLink, nil, nil, nil)
|
|
if err != nil {
|
|
return nil, errors.Wrap(err, "failed to load certificate from url")
|
|
}
|
|
|
|
content, err := io.ReadAll(response.Body)
|
|
if err != nil {
|
|
return nil, errors.Wrap(err, "failed to read response")
|
|
}
|
|
_ = response.Body.Close()
|
|
content = append(content, []byte("\n")...)
|
|
certs = append(certs, content...)
|
|
}
|
|
|
|
return certs, nil
|
|
}
|