gitea源码

12345678910111213141516171819202122232425262728293031323334353637383940
  1. // Copyright 2024 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package rpm
  4. import (
  5. "bytes"
  6. "io"
  7. "strings"
  8. packages_module "code.gitea.io/gitea/modules/packages"
  9. "github.com/ProtonMail/go-crypto/openpgp"
  10. "github.com/sassoftware/go-rpmutils"
  11. )
  12. func SignPackage(buf *packages_module.HashedBuffer, privateKey string) (*packages_module.HashedBuffer, error) {
  13. keyring, err := openpgp.ReadArmoredKeyRing(strings.NewReader(privateKey))
  14. if err != nil {
  15. return nil, err
  16. }
  17. h, err := rpmutils.SignRpmStream(buf, keyring[0].PrivateKey, nil)
  18. if err != nil {
  19. return nil, err
  20. }
  21. signBlob, err := h.DumpSignatureHeader(false)
  22. if err != nil {
  23. return nil, err
  24. }
  25. if _, err := buf.Seek(int64(h.OriginalSignatureHeaderSize()), io.SeekStart); err != nil {
  26. return nil, err
  27. }
  28. // create new buf with signature prefix
  29. return packages_module.CreateHashedBufferFromReader(io.MultiReader(bytes.NewReader(signBlob), buf))
  30. }