keyfactor

package
v0.0.0-...-6e04e87 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jan 20, 2025 License: Apache-2.0 Imports: 12 Imported by: 0

README

SignServer

Keyfactor SignServer Signer for Mender Artifact

The Keyfactor SignServer Signer for Mender Artifact is a custom signer for the Mender OTA update manager. It uses Keyfactor SignServer to sign Mender Artifacts.

Signing and Verification requests are forwarded to SignServer via the SignServer REST API, available in SignServer v6 and later.

Keyfactor SignServer enables organizations to automate the signing of Mender artifacts with a secure, auditable, and compliant process. PKI resources are stored in a secure, centralized location, and signing operations are performed by a dedicated signing service. This ensures that signing keys are never exposed to the Mender server. Additionally, SignServer enables compliance with internal IT policy by enforcing access policies.

Keyfactor SignServer Signer for Mender Artifact

Requirements

SignServer Configuration

The SignServer Signer for Mender Artifact requires a SignServer PlainSigner worker. The worker must be configured with the following properties:

Property Value
ACCEPTED_HASH_DIGEST_ALGORITHMS SHA-256, SHA-384, SHA-512
AUTHTYPE NOAUTH
CRYPTOTOKEN CryptoTokenP12
DEFAULTKEY signer00003
DISABLEKEYUSAGECOUNTER true
DO_LOGREQUEST_DIGEST
IMPLEMENTATION_CLASS org.signserver.module.cmssigner.PlainSigner
LOGREQUEST_DIGESTALGORITHM
NAME MenderPlainSigner
SIGNATUREALGORITHM NONEwithRSA
TYPE PROCESSABLE
CLIENTSIDEHASHING true

Usage

Authentication with the SignServer REST API is performed using a client certificate. The client certificate must be a PEM encoded X509v3 certificate with an unencrypted private key in PKCS#8 format. The certificate and private key can be stored in the same file or in separate files. The certificate and private key must be stored in a directory accessible to the context in which the signer is invoked. The following environment variables can be used to configure the signer:

Environment Variable Description Required
SIGNSERVER_HOSTNAME The host name of the SignServer instance to use for signing.
SIGNSERVER_CLIENT_CERT_PATH The path to the client certificate used to authenticate with the SignServer REST API.
SIGNSERVER_CLIENT_CERT_KEY_PATH The path to the private key for the client certificate. The signer will recognize if the private key is in the same file as the client certificate.
SIGNSERVER_CA_CERT_PATH The path to the root CA certificate (and any intermediates) used to verify the SignServer server certificate, if it wasn't signed by a trusted CA.

To use the SignServer Signer for Mender Artifact, invoke the Mender Artifact CLI with the --keyfactor-signserver-worker option:

mender-artifact sign <artifact-path> --keyfactor-signserver-worker <keyfactor-signserver-worker>

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type SignServerSigner

type SignServerSigner struct {
	// contains filtered or unexported fields
}

func NewSignServerSigner

func NewSignServerSigner(workerName string) (*SignServerSigner, error)

func (*SignServerSigner) Sign

func (s *SignServerSigner) Sign(message []byte) ([]byte, error)

func (*SignServerSigner) Verify

func (s *SignServerSigner) Verify(message, sig []byte) error

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL