1
0
mirror of https://github.com/SAP/jenkins-library.git synced 2025-01-04 04:07:16 +02:00
sap-jenkins-library/pkg/certutils/certutils.go
Vyacheslav Starostin 14c7feba1c
feat(artifactPrepareVersion): Support custom certificates (#4617)
* 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>
2023-10-11 13:58:38 +06:00

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
}