Skip to content

Commit

Permalink
Deliver a chain of intermediary CAs that sign an end-entity certifaca…
Browse files Browse the repository at this point in the history
…te to the validating TLS peer
  • Loading branch information
mattrm456 committed Dec 12, 2024
1 parent 791e73f commit 415b927
Show file tree
Hide file tree
Showing 11 changed files with 1,167 additions and 14 deletions.
32 changes: 32 additions & 0 deletions groups/ntc/ntca/ntca_encryptionclientoptions.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -162,6 +162,38 @@ void EncryptionClientOptions::setIdentityFile(
d_options.setIdentityFile(resourcePath, resourceOptions);
}

void EncryptionClientOptions::addIntermediary(
const ntca::EncryptionCertificate& certificate)
{
d_options.addIntermediary(certificate);
}

void EncryptionClientOptions::addIntermediaryData(
const bsl::vector<char>& resourceData)
{
d_options.addIntermediaryData(resourceData);
}

void EncryptionClientOptions::addIntermediaryData(
const bsl::vector<char>& resourceData,
const ntca::EncryptionResourceOptions& resourceOptions)
{
d_options.addIntermediaryData(resourceData, resourceOptions);
}

void EncryptionClientOptions::addIntermediaryFile(
const bsl::string& resourcePath)
{
d_options.addIntermediaryFile(resourcePath);
}

void EncryptionClientOptions::addIntermediaryFile(
const bsl::string& resourcePath,
const ntca::EncryptionResourceOptions& resourceOptions)
{
d_options.addIntermediaryFile(resourcePath, resourceOptions);
}

void EncryptionClientOptions::setPrivateKey(const ntca::EncryptionKey& key)
{
d_options.setPrivateKey(key);
Expand Down
41 changes: 41 additions & 0 deletions groups/ntc/ntca/ntca_encryptionclientoptions.h
Original file line number Diff line number Diff line change
Expand Up @@ -422,6 +422,47 @@ class EncryptionClientOptions
const bsl::string& resourcePath,
const ntca::EncryptionResourceOptions& resourceOptions);

/// Add the specified 'certificate' as an intermediate signer in the chain
/// of trust used by the end-entity certificate. Note that the effect of
/// calling this function is identical to simply calling 'addResource' with
/// resource options that indicate the resource contains an intermediate
/// certificate.
void addIntermediary(const ntca::EncryptionCertificate& certificate);

/// Add the specified encoded 'resourceData' as an intermediate signer in
/// the chain of trust used by the end-entity certificate. Note that the
/// effect of calling this function is identical to simply calling
/// 'addResourceData' with resource options that indicate the resource
/// contains an intermediate certificate.
void addIntermediaryData(const bsl::vector<char>& resourceData);

/// Add the specified encoded 'resourceData' decoded according to the
/// specified 'resourceOptions' as an intermediate signer in the chain of
/// trust used by the end-entity certificate. Note that the effect of
/// calling this function is identical to simply calling 'addResourceData'
/// with resource options that indicate the resource contains an
/// intermediate certificate.
void addIntermediaryData(
const bsl::vector<char>& resourceData,
const ntca::EncryptionResourceOptions& resourceOptions);

/// Set the path to the encoded intermediate signer in the chain of trust
/// used by the end-entity certificate data on disk to the specified
/// 'resourcePath'. Note that the effect of calling this function is
/// identical to simply calling 'addResourcePath' with resource options
/// that indicate the resource contains an intermediate certificate.
void addIntermediaryFile(const bsl::string& resourcePath);

/// Set the path to the encoded intermediate signer in the chain of trust
/// used by the end-entity certificate data on disk to the specified
/// 'resourcePath' decoded according to the specified 'resourceOptions'.
/// Note that the effect of calling this function is identical to simply
/// calling 'addResourcePath' with resource options that indicate the
/// resource contains an end-user certificate.
void addIntermediaryFile(
const bsl::string& resourcePath,
const ntca::EncryptionResourceOptions& resourceOptions);

/// Set the private key to the specified 'certificate'. Note that the
/// effect of calling this function is identical to simply calling
/// 'addResource' with resource options that indicate the resource contains
Expand Down
86 changes: 86 additions & 0 deletions groups/ntc/ntca/ntca_encryptionoptions.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -314,6 +314,92 @@ void EncryptionOptions::setIdentityFile(
this->addResource(resource);
}

void EncryptionOptions::addIntermediary(
const ntca::EncryptionCertificate& certificate)
{
ntca::EncryptionResourceOptions effectiveResourceOptions;
effectiveResourceOptions.setHint(
ntca::EncryptionResourceOptions::e_CERTIFICATE_INTERMEDIARY);

ntca::EncryptionResourceDescriptor resourceDescriptor;
resourceDescriptor.makeCertificate(certificate);

ntca::EncryptionResource resource;
resource.setDescriptor(resourceDescriptor);
resource.setOptions(effectiveResourceOptions);

this->addResource(resource);
}

void EncryptionOptions::addIntermediaryData(
const bsl::vector<char>& resourceData)
{
ntca::EncryptionResourceOptions effectiveResourceOptions;
effectiveResourceOptions.setHint(
ntca::EncryptionResourceOptions::e_CERTIFICATE_INTERMEDIARY);

ntca::EncryptionResourceDescriptor resourceDescriptor;
resourceDescriptor.makeData(resourceData);

ntca::EncryptionResource resource;
resource.setDescriptor(resourceDescriptor);
resource.setOptions(effectiveResourceOptions);

this->addResource(resource);
}

void EncryptionOptions::addIntermediaryData(
const bsl::vector<char>& resourceData,
const ntca::EncryptionResourceOptions& resourceOptions)
{
ntca::EncryptionResourceOptions effectiveResourceOptions = resourceOptions;
effectiveResourceOptions.setHint(
ntca::EncryptionResourceOptions::e_CERTIFICATE_INTERMEDIARY);

ntca::EncryptionResourceDescriptor resourceDescriptor;
resourceDescriptor.makeData(resourceData);

ntca::EncryptionResource resource;
resource.setDescriptor(resourceDescriptor);
resource.setOptions(effectiveResourceOptions);

this->addResource(resource);
}

void EncryptionOptions::addIntermediaryFile(const bsl::string& resourcePath)
{
ntca::EncryptionResourceOptions effectiveResourceOptions;
effectiveResourceOptions.setHint(
ntca::EncryptionResourceOptions::e_CERTIFICATE_INTERMEDIARY);

ntca::EncryptionResourceDescriptor resourceDescriptor;
resourceDescriptor.makePath(resourcePath);

ntca::EncryptionResource resource;
resource.setDescriptor(resourceDescriptor);
resource.setOptions(effectiveResourceOptions);

this->addResource(resource);
}

void EncryptionOptions::addIntermediaryFile(
const bsl::string& resourcePath,
const ntca::EncryptionResourceOptions& resourceOptions)
{
ntca::EncryptionResourceOptions effectiveResourceOptions = resourceOptions;
effectiveResourceOptions.setHint(
ntca::EncryptionResourceOptions::e_CERTIFICATE_INTERMEDIARY);

ntca::EncryptionResourceDescriptor resourceDescriptor;
resourceDescriptor.makePath(resourcePath);

ntca::EncryptionResource resource;
resource.setDescriptor(resourceDescriptor);
resource.setOptions(effectiveResourceOptions);

this->addResource(resource);
}

void EncryptionOptions::setPrivateKey(const ntca::EncryptionKey& key)
{
ntca::EncryptionResourceOptions effectiveResourceOptions;
Expand Down
41 changes: 41 additions & 0 deletions groups/ntc/ntca/ntca_encryptionoptions.h
Original file line number Diff line number Diff line change
Expand Up @@ -227,6 +227,47 @@ class EncryptionOptions
const bsl::string& resourcePath,
const ntca::EncryptionResourceOptions& resourceOptions);

/// Add the specified 'certificate' as an intermediate signer in the chain
/// of trust used by the end-entity certificate. Note that the effect of
/// calling this function is identical to simply calling 'addResource' with
/// resource options that indicate the resource contains an intermediate
/// certificate.
void addIntermediary(const ntca::EncryptionCertificate& certificate);

/// Add the specified encoded 'resourceData' as an intermediate signer in
/// the chain of trust used by the end-entity certificate. Note that the
/// effect of calling this function is identical to simply calling
/// 'addResourceData' with resource options that indicate the resource
/// contains an intermediate certificate.
void addIntermediaryData(const bsl::vector<char>& resourceData);

/// Add the specified encoded 'resourceData' decoded according to the
/// specified 'resourceOptions' as an intermediate signer in the chain of
/// trust used by the end-entity certificate. Note that the effect of
/// calling this function is identical to simply calling 'addResourceData'
/// with resource options that indicate the resource contains an
/// intermediate certificate.
void addIntermediaryData(
const bsl::vector<char>& resourceData,
const ntca::EncryptionResourceOptions& resourceOptions);

/// Set the path to the encoded intermediate signer in the chain of trust
/// used by the end-entity certificate data on disk to the specified
/// 'resourcePath'. Note that the effect of calling this function is
/// identical to simply calling 'addResourcePath' with resource options
/// that indicate the resource contains an intermediate certificate.
void addIntermediaryFile(const bsl::string& resourcePath);

/// Set the path to the encoded intermediate signer in the chain of trust
/// used by the end-entity certificate data on disk to the specified
/// 'resourcePath' decoded according to the specified 'resourceOptions'.
/// Note that the effect of calling this function is identical to simply
/// calling 'addResourcePath' with resource options that indicate the
/// resource contains an end-user certificate.
void addIntermediaryFile(
const bsl::string& resourcePath,
const ntca::EncryptionResourceOptions& resourceOptions);

/// Set the private key to the specified 'certificate'. Note that the
/// effect of calling this function is identical to simply calling
/// 'addResource' with resource options that indicate the resource contains
Expand Down
12 changes: 9 additions & 3 deletions groups/ntc/ntca/ntca_encryptionresourceoptions.h
Original file line number Diff line number Diff line change
Expand Up @@ -73,15 +73,21 @@ class EncryptionResourceOptions
/// The resource should contain a private key.
e_PRIVATE_KEY = 0,

/// The resource should contain an end-user certificate.
/// The resource should contain an end-entity certificate.
e_CERTIFICATE = 1,

/// The resource should contain a certificate authority that
/// participates in the chain of trust necessary to validate an
/// end-user certificate, but which may not be explicitly trusted by
/// the peer.
e_CERTIFICATE_INTERMEDIARY = 2,

/// The resource should contain one or more trusted certificate
/// authorities.
e_CERTIFICATE_AUTHORITY = 2,
e_CERTIFICATE_AUTHORITY = 3,

/// The contents of the resource are unknown.
e_ANY = 3
e_ANY = 4
};

Hint d_hint;
Expand Down
53 changes: 53 additions & 0 deletions groups/ntc/ntca/ntca_encryptionserveroptions.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -162,6 +162,59 @@ void EncryptionServerOptions::setIdentityFile(
d_options.setIdentityFile(resourcePath, resourceOptions);
}











void EncryptionServerOptions::addIntermediary(
const ntca::EncryptionCertificate& certificate)
{
d_options.addIntermediary(certificate);
}


void EncryptionServerOptions::addIntermediaryData(
const bsl::vector<char>& resourceData)
{
d_options.addIntermediaryData(resourceData);
}

void EncryptionServerOptions::addIntermediaryData(
const bsl::vector<char>& resourceData,
const ntca::EncryptionResourceOptions& resourceOptions)
{
d_options.addIntermediaryData(resourceData, resourceOptions);
}

void EncryptionServerOptions::addIntermediaryFile(
const bsl::string& resourcePath)
{
d_options.addIntermediaryFile(resourcePath);
}

void EncryptionServerOptions::addIntermediaryFile(
const bsl::string& resourcePath,
const ntca::EncryptionResourceOptions& resourceOptions)
{
d_options.addIntermediaryFile(resourcePath, resourceOptions);
}











void EncryptionServerOptions::setPrivateKey(const ntca::EncryptionKey& key)
{
d_options.setPrivateKey(key);
Expand Down
41 changes: 41 additions & 0 deletions groups/ntc/ntca/ntca_encryptionserveroptions.h
Original file line number Diff line number Diff line change
Expand Up @@ -405,6 +405,47 @@ class EncryptionServerOptions
const bsl::string& resourcePath,
const ntca::EncryptionResourceOptions& resourceOptions);

/// Add the specified 'certificate' as an intermediate signer in the chain
/// of trust used by the end-entity certificate. Note that the effect of
/// calling this function is identical to simply calling 'addResource' with
/// resource options that indicate the resource contains an intermediate
/// certificate.
void addIntermediary(const ntca::EncryptionCertificate& certificate);

/// Add the specified encoded 'resourceData' as an intermediate signer in
/// the chain of trust used by the end-entity certificate. Note that the
/// effect of calling this function is identical to simply calling
/// 'addResourceData' with resource options that indicate the resource
/// contains an intermediate certificate.
void addIntermediaryData(const bsl::vector<char>& resourceData);

/// Add the specified encoded 'resourceData' decoded according to the
/// specified 'resourceOptions' as an intermediate signer in the chain of
/// trust used by the end-entity certificate. Note that the effect of
/// calling this function is identical to simply calling 'addResourceData'
/// with resource options that indicate the resource contains an
/// intermediate certificate.
void addIntermediaryData(
const bsl::vector<char>& resourceData,
const ntca::EncryptionResourceOptions& resourceOptions);

/// Set the path to the encoded intermediate signer in the chain of trust
/// used by the end-entity certificate data on disk to the specified
/// 'resourcePath'. Note that the effect of calling this function is
/// identical to simply calling 'addResourcePath' with resource options
/// that indicate the resource contains an intermediate certificate.
void addIntermediaryFile(const bsl::string& resourcePath);

/// Set the path to the encoded intermediate signer in the chain of trust
/// used by the end-entity certificate data on disk to the specified
/// 'resourcePath' decoded according to the specified 'resourceOptions'.
/// Note that the effect of calling this function is identical to simply
/// calling 'addResourcePath' with resource options that indicate the
/// resource contains an end-user certificate.
void addIntermediaryFile(
const bsl::string& resourcePath,
const ntca::EncryptionResourceOptions& resourceOptions);

/// Set the private key to the specified 'certificate'. Note that the
/// effect of calling this function is identical to simply calling
/// 'addResource' with resource options that indicate the resource contains
Expand Down
Loading

0 comments on commit 415b927

Please sign in to comment.