Skip to content

Commit

Permalink
Merge pull request #27 from Keyfactor/release-1.0
Browse files Browse the repository at this point in the history
release 1.0 to main
  • Loading branch information
fiddlermikey authored Apr 30, 2024
2 parents 99e5bfd + 6cddd9e commit f060119
Show file tree
Hide file tree
Showing 5 changed files with 196 additions and 113 deletions.
5 changes: 4 additions & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -17,4 +17,7 @@ Convert GlobalSign status codes to Keyfactor status codes for syncing
Fix authentication bug when picking up certificates

1.0.15
Better datetime parsing of returned certificates
Better datetime parsing of returned certificates

1.0.16
Fix for adding additional SANs to certificate requests
20 changes: 16 additions & 4 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,28 +1,39 @@

# GlobalSign Managed SSL AnyGateway

This integration allows for the Synchronization, Enrollment, and Revocation of TLS Certificates from the GlobalSign Certificate Center.

#### Integration status: Production - Ready for use in production environments.

## About the Keyfactor AnyCA Gateway DCOM Connector

## About the Keyfactor AnyGateway CA Connector

This repository contains an AnyGateway CA Connector, which is a plugin to the Keyfactor AnyGateway. AnyGateway CA Connectors allow Keyfactor Command to be used for inventory, issuance, and revocation of certificates from a third-party certificate authority.

This repository contains an AnyCA Gateway Connector, which is a plugin to the Keyfactor AnyGateway. AnyCA Gateway Connectors allow Keyfactor Command to be used for inventory, issuance, and revocation of certificates from a third-party certificate authority.

## Support for GlobalSign Managed SSL AnyGateway

GlobalSign Managed SSL AnyGateway is supported by Keyfactor for Keyfactor customers. If you have a support issue, please open a support ticket via the Keyfactor Support Portal at https://support.keyfactor.com

###### To report a problem or suggest a new feature, use the **[Issues](../../issues)** tab. If you want to contribute actual bug fixes or proposed enhancements, use the **[Pull requests](../../pulls)** tab.

---


---





## Keyfactor AnyCA Gateway Framework Supported
The Keyfactor gateway framework implements common logic shared across various gateway implementations and handles communication with Keyfactor Command. The gateway framework hosts gateway implementations or plugins that understand how to communicate with specific CAs. This allows you to integrate your third-party CAs with Keyfactor Command such that they behave in a manner similar to the CAs natively supported by Keyfactor Command.




This gateway extension was compiled against version of the AnyCA Gateway DCOM Framework. You will need at least this version of the framework Installed. If you have a later AnyGateway Framework Installed you will probably need to add binding redirects in the CAProxyServer.exe.config file to make things work properly.


[Keyfactor CAGateway Install Guide](https://software.keyfactor.com/Guides/AnyGateway_Generic/Content/AnyGateway/Introduction.htm)



Expand Down Expand Up @@ -208,3 +219,4 @@ There are no specific Changes for the ServiceSettings section. Refer to the AnyG
}
```


240 changes: 135 additions & 105 deletions src/GlobalSignCAProxy/Api/GlobalSignEnrollRequest.cs
Original file line number Diff line number Diff line change
@@ -1,112 +1,142 @@
// Copyright 2021 Keyfactor
// Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License.
// You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
// Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions
// and limitations under the License.

// Copyright 2021 Keyfactor
// Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License.
// You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
// Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions
// and limitations under the License.

using CSS.Common.Logging;

using Keyfactor.Extensions.AnyGateway.GlobalSign.Services.Order;

using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace Keyfactor.Extensions.AnyGateway.GlobalSign.Api
{
public class GlobalSignEnrollRequest
{
internal GlobalSignCAConfig Config;
public class GlobalSignEnrollRequest : LoggingClientBase
{
internal GlobalSignCAConfig Config;

public GlobalSignEnrollRequest(GlobalSignCAConfig config)
{
Config = config;
}
public string CSR { get; set; }
public string ProductCode { get; set; }
public string CommonName { get; set; }
public string BaseOption
{
get
{
if (!string.IsNullOrEmpty(CommonName))
{
if (CommonName.StartsWith("*"))
{
return "wildcard";
}
else
{
return null;
}
}
else
{
return null;
}
}
}
public string OrderKind { get; set; }
public string Licenses { get; set; }
public string Months { get; set; }
public string MsslProfileId { get; set; }
public string MsslDomainId { get; set; }
public string FirstName { get; set; }
public string LastName { get; set; }
public string Phone { get; set; }
public string Email { get; set; }
public List<string> SANs { get; set; }
public PvSealInfo Seal { get; set; }
public MsslEvProfileInfo EVProfile { get; set; }
public BmV2PvOrderRequest Request
{
get
{
BmV2PvOrderRequest request = new BmV2PvOrderRequest();
request.OrderRequestHeader = new OrderRequestHeader { AuthToken = Config.GetOrderAuthToken() };
request.MSSLProfileID = MsslProfileId;
request.MSSLDomainID = MsslDomainId;
request.ContactInfo = new ContactInfo
{
FirstName = FirstName,
LastName = LastName,
Phone = Phone,
Email = Email
};
if (SANs != null)
{
if (SANs.Count > 0)
{
List<SANEntry> sans = new List<SANEntry>();
foreach (string item in SANs)
{
SANEntry entry = new SANEntry();
entry.SubjectAltName = item;
if (item.StartsWith("*"))
{
entry.SubjectAltName = "13";
}
else
{
entry.SubjectAltName = "7";
}
}
request.SANEntries = sans.ToArray();
}
}
ValidityPeriod validityPeriod = new ValidityPeriod();
validityPeriod.Months = Months;
request.OrderRequestParameter = new OrderRequestParameter
{
ProductCode = ProductCode,
OrderKind = OrderKind,
Licenses = Licenses,
CSR = CSR,
ValidityPeriod = validityPeriod
};
if (!string.IsNullOrEmpty(BaseOption))
{
request.OrderRequestParameter.BaseOption = BaseOption;
}
public GlobalSignEnrollRequest(GlobalSignCAConfig config)
{
Config = config;
}

public string CSR { get; set; }
public string ProductCode { get; set; }
public string CommonName { get; set; }

public string BaseOption
{
get
{
if (!string.IsNullOrEmpty(CommonName))
{
if (CommonName.StartsWith("*"))
{
return "wildcard";
}
else
{
return null;
}
}
else
{
return null;
}
}
}

public string OrderKind { get; set; }
public string Licenses { get; set; }
public string Months { get; set; }
public string MsslProfileId { get; set; }
public string MsslDomainId { get; set; }
public string FirstName { get; set; }
public string LastName { get; set; }
public string Phone { get; set; }
public string Email { get; set; }
public List<string> SANs { get; set; }
public PvSealInfo Seal { get; set; }
public MsslEvProfileInfo EVProfile { get; set; }

public BmV2PvOrderRequest Request
{
get
{
BmV2PvOrderRequest request = new BmV2PvOrderRequest();
request.OrderRequestHeader = new OrderRequestHeader { AuthToken = Config.GetOrderAuthToken() };
request.MSSLProfileID = MsslProfileId;
request.MSSLDomainID = MsslDomainId;
request.ContactInfo = new ContactInfo
{
FirstName = FirstName,
LastName = LastName,
Phone = Phone,
Email = Email
};
if (SANs != null)
{
if (SANs.Count > 0)
{
List<SANEntry> sans = new List<SANEntry>();
foreach (string item in SANs)
{
if (string.Equals(item, CommonName, System.StringComparison.OrdinalIgnoreCase))
{
Logger.Info($"SAN Entry {item} matches CN, removing from request");
continue;
}
SANEntry entry = new SANEntry();
entry.SubjectAltName = item;
StringBuilder sb = new StringBuilder();
sb.Append($"Adding SAN entry of type ");
if (item.StartsWith("*"))
{
entry.SANOptionType = "13";
sb.Append("WILDCARD");
}
else
{
entry.SANOptionType = "7";
sb.Append("FQDN");
}
sb.Append($" and value {item} to request");
Logger.Info(sb.ToString());
sans.Add(entry);
}
request.SANEntries = sans.ToArray();
}
}
List<Option> options = new List<Option>();
if (request.SANEntries.Count() > 0)
{
var opt = new Option();
opt.OptionName = "SAN";
opt.OptionValue = "True";
options.Add(opt);
}
ValidityPeriod validityPeriod = new ValidityPeriod();
validityPeriod.Months = Months;
request.OrderRequestParameter = new OrderRequestParameter
{
ProductCode = ProductCode,
OrderKind = OrderKind,
Licenses = Licenses,
CSR = CSR,
ValidityPeriod = validityPeriod,
Options = options.ToArray()
};
if (!string.IsNullOrEmpty(BaseOption))
{
request.OrderRequestParameter.BaseOption = BaseOption;
}

return request;
}
}
}
}
return request;
}
}
}
}
12 changes: 12 additions & 0 deletions src/GlobalSignCAProxy/Client/GlobalSignApiClient.cs
Original file line number Diff line number Diff line change
Expand Up @@ -257,6 +257,18 @@ public EnrollmentResult Enroll(GlobalSignEnrollRequest enrollRequest)
Logger.MethodEntry(ILogExtensions.MethodLogLevel.Debug);
using (this.OrderService)
{
var rawRequest = enrollRequest.Request;
Logger.Trace($"Request details:");
Logger.Trace($"Profile ID: {rawRequest.MSSLProfileID}");
Logger.Trace($"Domain ID: {rawRequest.MSSLDomainID}");
Logger.Trace($"Contact Info: {rawRequest.ContactInfo.FirstName}, {rawRequest.ContactInfo.LastName}, {rawRequest.ContactInfo.Email}, {rawRequest.ContactInfo.Phone}");
Logger.Trace($"SAN Count: {rawRequest.SANEntries.Count()}");
if (rawRequest.SANEntries.Count() > 0)
{
Logger.Trace($"SANs: {string.Join(",", rawRequest.SANEntries.Select(s => s.SubjectAltName))}");
}
Logger.Trace($"Product Code: {rawRequest.OrderRequestParameter.ProductCode}");
Logger.Trace($"Order Kind: {rawRequest.OrderRequestParameter.OrderKind}");
var response = OrderService.PVOrder(enrollRequest.Request);
if (response.OrderResponseHeader.SuccessCode == 0)
{
Expand Down
Loading

0 comments on commit f060119

Please sign in to comment.