Server URL |
https://interop.redwax.eu
|
Time Source |
System Clock
|
Serial Numbers |
Random
|
Certificate Sign Request Demo/Interop
Interoperate with the Redwax Certificate Sign Request module.
We have implemented a RFC2986 PKCS10 / Certificate Sign Request endpoint that allows you to test your client implementation against a Redwax Server.
This module allows you to work with a Microsoft CertEnroll certificate request as implemented by Internet Explorer 11.
The code being run is the most up to date build from trunk/main in source control, and is built and deployed automatically. The Redwax Interop server is for testing purposes only.
data:image/s3,"s3://crabby-images/a531e/a531ed75a4885d3f77c703a41bd1b9bd7c3f81f4" alt=""
Redwax Module Configuration
The following configuration is used to implement this CSR endpoint. The configuration below is added to a standard secure virtualhost Apache configuration, as described here.
Configuration
Here we set the csr handler, and set the certificates and keys to be used for signing the certificate.
<IfModule !ca_module>
LoadModule ca_module /usr/lib64/httpd/modules/mod_ca.so
</IfModule>
<IfModule !ca_simple_module>
LoadModule ca_simple_module /usr/lib64/httpd/modules/mod_ca_simple.so
</IfModule>
<IfModule !csr_module>
LoadModule csr_module /usr/lib64/httpd/modules/mod_csr.so
</IfModule>
<Location /test/simple/csr>
Require all granted
SetHandler csr
CsrParamChallenge challenge
CsrSubjectRequest CN
CsrSubjectRequest O
CsrSubjectRequest C
CsrSubjectAltNameRequest rfc822Name
</Location>
CertEnroll with Microsoft Internet Explorer 11
The following example form shows how to generate a request based on the CertEnroll functionality in Internet Explorer 11.
Html Form
To request a certificate be generated, submit the form below.
Object Tag
The following object tag must be present in the page to embed the
objCertEnrollClassFactory
and make this accessible from
the javascript.
<object classid="clsid:884e2049-217d-11da-b2a4-000e7bbb2b09"
id="objCertEnrollClassFactory"
height="0"
width="0"></object>
Javascript
The javascript used to trigger the CertEnroll functionality can be downloaded here, and is included for reference below.
/* make sure we can only submit once */
document
.getElementById('createform')
.addEventListener(
"submit",
function certenroll(event) {
document.getElementById('submit').disabled = true;
try {
var objCSP = objCertEnrollClassFactory
.CreateObject("X509Enrollment.CCspInformation");
var objCSPs = objCertEnrollClassFactory
.CreateObject("X509Enrollment.CCspInformations");
var objPrivateKey = objCertEnrollClassFactory
.CreateObject("X509Enrollment.CX509PrivateKey");
var objRequest = objCertEnrollClassFactory
.CreateObject("X509Enrollment.CX509CertificateRequestPkcs10")
var objObjectIds = objCertEnrollClassFactory
.CreateObject("X509Enrollment.CObjectIds");
var objObjectId = objCertEnrollClassFactory
.CreateObject("X509Enrollment.CObjectId");
var objX509ExtensionEnhancedKeyUsage = objCertEnrollClassFactory
.CreateObject("X509Enrollment.CX509ExtensionEnhancedKeyUsage");
var objExtensionTemplate = objCertEnrollClassFactory
.CreateObject("X509Enrollment.CX509ExtensionTemplateName")
var objDn = objCertEnrollClassFactory
.CreateObject("X509Enrollment.CX500DistinguishedName")
var objObjectIdChallenge = objCertEnrollClassFactory
.CreateObject("X509Enrollment.CObjectId");
var objX509ExtensionChallenge = objCertEnrollClassFactory
.CreateObject("X509Enrollment.CX509Extension");
var objEnroll = objCertEnrollClassFactory
.CreateObject("X509Enrollment.CX509Enrollment")
/*
* initialize the CSP using the desired Cryptograhic
* Service Provider
*/
objCSP
.InitializeFromName(
"Microsoft Enhanced RSA and AES Cryptographic Provider");
/* add this CSP to the CSP collection */
objCSPs.Add(objCSP);
/*
* provide key container name, key length and key spec
* to the private key object
*/
// objPrivateKey.ContainerName = $('#name').val();
objPrivateKey.Length = 4096;
objPrivateKey.KeySpec = 1; // AT_KEYEXCHANGE = 1
objPrivateKey.ProviderType = '24'; // XCN_PROV_RSA_AES
// = 24
/*
* provide the CSP collection object (in this case
* containing only 1 CSP object)
*/
/* to the private key object */
objPrivateKey.CspInformations = objCSPs;
/* initialize P10 based on private key */
objRequest.InitializeFromPrivateKey(1, objPrivateKey,
""); // context user = 1
/* 1.3.6.1.5.5.7.3.2 Oid - extension */
objObjectId.InitializeFromValue("1.3.6.1.5.5.7.3.2");
objObjectIds.Add(objObjectId);
objX509ExtensionEnhancedKeyUsage
.InitializeEncode(objObjectIds);
objRequest.X509Extensions
.Add(objX509ExtensionEnhancedKeyUsage);
/* 1.3.6.1.5.5.7.3.3 Oid - extension */
// objExtensionTemplate.InitializeEncode("1.3.6.1.5.5.7.3.3");
// objRequest.X509Extensions.Add(objExtensionTemplate);
/* DN related stuff */
objDn.Encode("CN="
+ document.getElementById('name').value, 0); // XCN_CERT_NAME_STR_NONE
// = 0
objRequest.Subject = objDn;
// objChallengeObjectId.
// InitializeFromName(CERTENROLL_OBJECTID.XCN_OID_RSA_challengePwd);
// objChallengeObjectId.InitializeFromValue("1.2.840.113549.1.9.7");
objObjectIdChallenge
.InitializeFromValue("1.2.840.113549.1.9.7");
objX509ExtensionChallenge.Initialize(
objObjectIdChallenge, 6, window
.btoa('Hello, world')); // XCN_CRYPT_STRING_BASE64_ANY
// = 6
objRequest.X509Extensions
.Add(objX509ExtensionChallenge);
/* enroll */
objEnroll.InitializeFromRequest(objRequest);
document.getElementById('pkcs10').value = objEnroll
.CreateRequest(3); // XCN_CRYPT_STRING_BASE64REQUESTHEADER
// = 3
/* send the request */
var xhr = new XMLHttpRequest();
xhr.onerror = function() {
alert('A network error occcurred trying to contact the certificate' +
'authority. Click create to try again.');
document.getElementById('submit').disabled = false;
}
xhr.onload = function() {
if (xhr.status != 200) {
alert('The certificate authority responded with '
+ xhr.status + ': ' + xhr.statusText); // e.g.
// 404:
// Not
// Found
document.getElementById('submit').disabled = false;
} else {
try {
var allow = 4; // AllowUntrustedRoot
objEnroll.InstallResponse(allow,
xhr.response, 0, "");
} catch (ex) {
console.log(ex);
}
alert('The certificate has been installed successfully.');
// document.getElementById('continue').disabled
// = false;
}
};
xhr.open('POST',
document.getElementById('createform').action,
true);
xhr.setRequestHeader('Content-Type',
'application/x-www-form-urlencoded');
xhr
.setRequestHeader('Accept',
'application/pkcs7-mime');
xhr.responseType = 'text';
// var formData = new
// FormData(document.getElementById('createform'));
var formData = encodeURIComponent('pkcs10')
+ '='
+ encodeURIComponent(document
.getElementById('pkcs10').value);
console.log(formData);
xhr.send(formData);
event.preventDefault();
return false;
} catch (ex) {
console.log(ex);
if (ex instanceof TypeError) {
alert('Microsoft CertEnroll is not supported on this browser');
} else {
alert(ex);
}
document.getElementById('submit').disabled = false;
event.preventDefault();
return false;
}
return true;
});