summaryrefslogtreecommitdiff
path: root/pages/account/4.php
diff options
context:
space:
mode:
authorMarkus Warg <mw@it-sls.de>2010-03-29 09:54:06 +0200
committerMarkus Warg <mw@it-sls.de>2010-03-29 09:54:06 +0200
commit9dceece06fbdc98add6f76f0b1aec05891a394c4 (patch)
treef7227c28ca5f79f30c2ec81ba1a09a4fe3972436 /pages/account/4.php
parent5b68967def224a00f54eb54946ff17301bbd3cdb (diff)
downloadcacert-devel-9dceece06fbdc98add6f76f0b1aec05891a394c4.tar.gz
cacert-devel-9dceece06fbdc98add6f76f0b1aec05891a394c4.tar.xz
cacert-devel-9dceece06fbdc98add6f76f0b1aec05891a394c4.zip
remove cacert/ prefix
Diffstat (limited to 'pages/account/4.php')
-rw-r--r--pages/account/4.php190
1 files changed, 190 insertions, 0 deletions
diff --git a/pages/account/4.php b/pages/account/4.php
new file mode 100644
index 0000000..a4d6597
--- /dev/null
+++ b/pages/account/4.php
@@ -0,0 +1,190 @@
+<? /*
+ LibreSSL - CAcert web application
+ Copyright (C) 2004-2008 CAcert Inc.
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; version 2 of the License.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+*/ ?>
+<? if(array_key_exists('HTTP_USER_AGENT',$_SERVER) && strstr($_SERVER['HTTP_USER_AGENT'], "MSIE")) { ?>
+<object classid="clsid:127698e4-e730-4e5c-a2b1-21490a70c8a1" codebase="/xenroll.cab#Version=5,131,3659,0" id="cec">
+<?=_("You must enable ActiveX for this to work. On Vista you have to add this website to the list of trusted sites in the internet-settings.")?><?=_("Go to Extras->Internet Options->Security->Trusted Websites, click on Custom Level, check ActiveX control elements that are not marked as safe initialized on start in scripts")?>
+</object>
+<form method="post" action="account.php" name="CertReqForm"><p>
+<input type="hidden" name="session" value="UsedXenroll">
+<?=_("Key Strength:")?> <select name="CspProvider"></select>
+<input type="hidden" name="oldid" value="<?=$id?>">
+<INPUT TYPE=HIDDEN NAME="CSR">
+<input type="hidden" name="keytype" value="MS">
+<input type="submit" name="GenReq" value="Create Certificate"><br>
+</p></form>
+<script type="text/vbscript" language="vbscript">
+<!--
+Function GetProviderList()
+ Dim CspList, cspIndex, ProviderName
+ On Error Resume Next
+
+ count = 0
+ base = 0
+ enhanced = 0
+ CspList = ""
+ ProviderName = ""
+
+ // Vista:
+ Set csps = CreateObject("X509Enrollment.CCspInformations")
+ If IsObject(csps) Then
+ csps.AddAvailableCsps()
+ Document.CertReqForm.keytype.value="VI"
+ For j = 0 to csps.Count-1
+ Set oOption = document.createElement("OPTION")
+ oOption.text = csps.ItemByIndex(j).Name
+ oOption.value = j
+ Document.CertReqForm.CspProvider.add(oOption)
+ Next
+
+ Else
+
+ // 2000,XP:
+
+ For ProvType = 0 to 13
+ cspIndex = 0
+ cec.ProviderType = ProvType
+ ProviderName = cec.enumProviders(cspIndex,0)
+
+ while ProviderName <> ""
+ Set oOption = document.createElement("OPTION")
+ oOption.text = ProviderName
+ oOption.value = ProvType
+ Document.CertReqForm.CspProvider.add(oOption)
+ if ProviderName = "Microsoft Base Cryptographic Provider v1.0" Then
+ base = count
+ end if
+ if ProviderName = "Microsoft Enhanced Cryptographic Provider v1.0" Then
+ enhanced = count
+ end if
+ cspIndex = cspIndex +1
+ ProviderName = ""
+ ProviderName = cec.enumProviders(cspIndex,0)
+ count = count + 1
+ wend
+ Next
+ Document.CertReqForm.CspProvider.selectedIndex = base
+ if enhanced then
+ Document.CertReqForm.CspProvider.selectedIndex = enhanced
+ end if
+ End If
+End Function
+
+Function CSR(keyflags)
+ CSR = ""
+ szName = ""
+
+
+ // Vista
+ if Document.CertReqForm.keytype.value="VI" Then
+
+ Dim g_objClassFactory
+ Dim obj
+ Dim objPrivateKey
+ Dim g_objRequest
+ Dim g_objRequestCMC
+
+ Set g_objClassFactory=CreateObject("X509Enrollment.CX509EnrollmentWebClassFactory")
+ Set obj=g_objClassFactory.CreateObject("X509Enrollment.CX509Enrollment")
+ Set objPrivateKey=g_objClassFactory.CreateObject("X509Enrollment.CX509PrivateKey")
+ Set objRequest=g_objClassFactory.CreateObject("X509Enrollment.CX509CertificateRequestPkcs10")
+ //Msgbox exit function
+ objPrivateKey.ProviderName = Document.CertReqForm.CspProvider(Document.CertReqForm.CspProvider.selectedIndex).text
+ // "Microsoft Enhanced RSA and AES Cryptographic Provider"
+ objPrivateKey.ProviderType = "24"
+ objPrivateKey.KeySpec = "1"
+ objPrivateKey.ExportPolicy = 1
+ objRequest.InitializeFromPrivateKey 1, objPrivateKey, ""
+ Set objDN = g_objClassFactory.CreateObject("X509Enrollment.CX500DistinguishedName")
+ objDN.Encode("CN=CAcertRequest")
+ objRequest.Subject = objDN
+
+ // obj.Initialize(1)
+ obj.InitializeFromRequest(objRequest)
+ obj.CertificateDescription="Description"
+ obj.CertificateFriendlyName="FriendlyName"
+ CSR=obj.CreateRequest(1)
+ If len(CSR)<>0 Then Exit Function
+ Msgbox "<?=_("Error while generating the certificate-request. Please make sure that you have added this website to the list of trusted sites in the Internet-Options menu!")?>"
+
+ else
+ // XP
+
+ cec.HashAlgorithm = "MD5"
+ err.clear
+ On Error Resume Next
+ set options = document.all.CspProvider.options
+ index = options.selectedIndex
+ cec.providerName = options(index).text
+ tmpProviderType = options(index).value
+ cec.providerType = tmpProviderType
+ cec.KeySpec = 2
+ if tmpProviderType < 2 Then
+ cec.KeySpec = 1
+ end if
+ cec.GenKeyFlags = &h04000001 OR keyflags
+ CSR = cec.createPKCS10(szName, "1.3.6.1.5.5.7.3.2")
+ if len(CSR)<>0 then Exit Function
+ cec.GenKeyFlags = &h04000000 OR keyflags
+ CSR = cec.createPKCS10(szName, "1.3.6.1.5.5.7.3.2")
+ if len(CSR)<>0 then Exit Function
+ if cec.providerName = "Microsoft Enhanced Cryptographic Provider v1.0" Then
+ if MsgBox("<?=_("The 1024-bit key generation failed. Would you like to try 512 instead?")?>", vbOkCancel)=vbOk Then
+ cec.providerName = "Microsoft Base Cryptographic Provider v1.0"
+ else
+ Exit Function
+ end if
+ end if
+ cec.GenKeyFlags = 1 OR keyflags
+ CSR = cec.createPKCS10(szName, "1.3.6.1.5.5.7.3.2")
+ if len(CSR)<>0 then Exit Function
+ cec.GenKeyFlags = keyflags
+ CSR = cec.createPKCS10(szName, "1.3.6.1.5.5.7.3.2")
+ if len(CSR)<>0 then Exit Function
+ cec.GenKeyFlags = 0
+ CSR = cec.createPKCS10(szName, "1.3.6.1.5.5.7.3.2")
+ End if
+End Function
+
+Sub GenReq_OnClick
+ Dim TheForm
+ Set TheForm = Document.CertReqForm
+ err.clear
+ result = CSR(2)
+ if len(result)=0 Then
+ result = MsgBox("Unable to generate PKCS#10.", 0, "Alert")
+ Exit Sub
+ end if
+ TheForm.CSR.Value = result
+ TheForm.Submit
+ Exit Sub
+End Sub
+
+GetProviderList()
+-->
+</script>
+<? } else { ?>
+<p>
+<form method="post" action="account.php">
+<input type="hidden" name="keytype" value="NS">
+<?=_("Keysize:")?> <keygen name="SPKAC" challenge="<? $_SESSION['spkac_hash']=make_hash(); echo $_SESSION['spkac_hash']; ?>">
+
+<input type="submit" name="submit" value="<?=_("Create Certificate Request")?>">
+<input type="hidden" name="oldid" value="<?=$id?>">
+</form>
+</p>
+<? } ?>