1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #include <sal/config.h>
25 #include <rtl/ustring.hxx>
26 #include <com/sun/star/security/ExtAltNameType.hpp>
27 #include <com/sun/star/security/CertAltNameEntry.hpp>
28 #include <com/sun/star/beans/NamedValue.hpp>
29 #include <comphelper/sequence.hxx>
30 #include <o3tl/char16_t2wchar_t.hxx>
32 #include "sanextension_mscryptimpl.hxx"
34 using namespace ::com::sun::star
;
35 using namespace ::com::sun::star::uno
;
36 using namespace ::com::sun::star::security
;
38 using ::com::sun::star::security::XCertificateExtension
;
41 SanExtensionImpl::SanExtensionImpl() :
46 SanExtensionImpl::~SanExtensionImpl() {
50 //Methods from XCertificateExtension
51 sal_Bool SAL_CALL
SanExtensionImpl::isCritical() {
55 css::uno::Sequence
< sal_Int8
> SAL_CALL
SanExtensionImpl::getExtensionId() {
59 css::uno::Sequence
< sal_Int8
> SAL_CALL
SanExtensionImpl::getExtensionValue() {
63 //Methods from XSanExtension
64 css::uno::Sequence
< css::security::CertAltNameEntry
> SAL_CALL
SanExtensionImpl::getAlternativeNames(){
66 if (!m_Entries
.hasElements())
68 CERT_ALT_NAME_INFO
*subjectName
;
70 CryptDecodeObjectEx(X509_ASN_ENCODING
, X509_ALTERNATE_NAME
, reinterpret_cast<unsigned char*>(m_xExtnValue
.getArray()), m_xExtnValue
.getLength(), CRYPT_DECODE_ALLOC_FLAG
| CRYPT_DECODE_NOCOPY_FLAG
, nullptr,&subjectName
, &size
);
72 auto arrCertAltNameEntry
= std::make_unique
<CertAltNameEntry
[]>(subjectName
->cAltEntry
);
74 for (unsigned int i
= 0; i
< static_cast<unsigned int>(subjectName
->cAltEntry
); i
++){
75 PCERT_ALT_NAME_ENTRY pEntry
= &subjectName
->rgAltEntry
[i
];
77 switch(pEntry
->dwAltNameChoice
) {
78 case CERT_ALT_NAME_OTHER_NAME
:
80 arrCertAltNameEntry
[i
].Type
= ExtAltNameType_OTHER_NAME
;
81 PCERT_OTHER_NAME pOtherName
= pEntry
->pOtherName
;
83 css::beans::NamedValue otherNameProp
;
84 otherNameProp
.Name
= OUString::createFromAscii(pOtherName
->pszObjId
);
86 Sequence
< sal_Int8
> otherName( pOtherName
->Value
.cbData
) ;
87 for( unsigned int n
= 0; n
< static_cast<unsigned int>(pOtherName
->Value
.cbData
) ; n
++ )
88 otherName
[n
] = *( pOtherName
->Value
.pbData
+ n
) ;
90 otherNameProp
.Value
<<= otherName
;
92 arrCertAltNameEntry
[i
].Value
<<= otherNameProp
;
95 case CERT_ALT_NAME_RFC822_NAME
:
96 arrCertAltNameEntry
[i
].Type
= ExtAltNameType_RFC822_NAME
;
97 arrCertAltNameEntry
[i
].Value
<<= OUString(o3tl::toU(pEntry
->pwszRfc822Name
));
99 case CERT_ALT_NAME_DNS_NAME
:
100 arrCertAltNameEntry
[i
].Type
= ExtAltNameType_DNS_NAME
;
101 arrCertAltNameEntry
[i
].Value
<<= OUString(o3tl::toU(pEntry
->pwszDNSName
));
103 case CERT_ALT_NAME_DIRECTORY_NAME
:
105 arrCertAltNameEntry
[i
].Type
= ExtAltNameType_DIRECTORY_NAME
;
108 case CERT_ALT_NAME_URL
:
109 arrCertAltNameEntry
[i
].Type
= ExtAltNameType_URL
;
110 arrCertAltNameEntry
[i
].Value
<<= OUString(o3tl::toU(pEntry
->pwszURL
));
112 case CERT_ALT_NAME_IP_ADDRESS
:
114 arrCertAltNameEntry
[i
].Type
= ExtAltNameType_IP_ADDRESS
;
116 Sequence
< sal_Int8
> ipAddress( pEntry
->IPAddress
.cbData
) ;
117 for( unsigned int n
= 0; n
< pEntry
->IPAddress
.cbData
; n
++ )
118 ipAddress
[n
] = *( pEntry
->IPAddress
.pbData
+ n
) ;
120 arrCertAltNameEntry
[i
].Value
<<= ipAddress
;
123 case CERT_ALT_NAME_REGISTERED_ID
:
124 arrCertAltNameEntry
[i
].Type
= ExtAltNameType_REGISTERED_ID
;
125 arrCertAltNameEntry
[i
].Value
<<= OUString::createFromAscii(pEntry
->pszRegisteredID
);
129 m_Entries
= ::comphelper::arrayToSequence
< css::security::CertAltNameEntry
>(arrCertAltNameEntry
.get(), subjectName
->cAltEntry
);
135 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */