1*cdf0e10cSrcweir/*************************************************************************
2*cdf0e10cSrcweir *
3*cdf0e10cSrcweir * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4*cdf0e10cSrcweir *
5*cdf0e10cSrcweir * Copyright 2000, 2010 Oracle and/or its affiliates.
6*cdf0e10cSrcweir *
7*cdf0e10cSrcweir * OpenOffice.org - a multi-platform office productivity suite
8*cdf0e10cSrcweir *
9*cdf0e10cSrcweir * This file is part of OpenOffice.org.
10*cdf0e10cSrcweir *
11*cdf0e10cSrcweir * OpenOffice.org is free software: you can redistribute it and/or modify
12*cdf0e10cSrcweir * it under the terms of the GNU Lesser General Public License version 3
13*cdf0e10cSrcweir * only, as published by the Free Software Foundation.
14*cdf0e10cSrcweir *
15*cdf0e10cSrcweir * OpenOffice.org is distributed in the hope that it will be useful,
16*cdf0e10cSrcweir * but WITHOUT ANY WARRANTY; without even the implied warranty of
17*cdf0e10cSrcweir * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18*cdf0e10cSrcweir * GNU Lesser General Public License version 3 for more details
19*cdf0e10cSrcweir * (a copy is included in the LICENSE file that accompanied this code).
20*cdf0e10cSrcweir *
21*cdf0e10cSrcweir * You should have received a copy of the GNU Lesser General Public License
22*cdf0e10cSrcweir * version 3 along with OpenOffice.org.  If not, see
23*cdf0e10cSrcweir * <http://www.openoffice.org/license.html>
24*cdf0e10cSrcweir * for a copy of the LGPLv3 License.
25*cdf0e10cSrcweir *
26*cdf0e10cSrcweir ************************************************************************/
27*cdf0e10cSrcweir
28*cdf0e10cSrcweir#ifndef __com_sun_star_xml_crypto_xsecurityenvironment_idl_
29*cdf0e10cSrcweir#define __com_sun_star_xml_crypto_xsecurityenvironment_idl_
30*cdf0e10cSrcweir
31*cdf0e10cSrcweir#ifndef __com_sun_star_uno_SecurityException_idl__
32*cdf0e10cSrcweir#include <com/sun/star/uno/SecurityException.idl>
33*cdf0e10cSrcweir#endif
34*cdf0e10cSrcweir
35*cdf0e10cSrcweir#include <com/sun/star/uno/XInterface.idl>
36*cdf0e10cSrcweir#include <com/sun/star/uno/Exception.idl>
37*cdf0e10cSrcweir#include <com/sun/star/security/XCertificate.idl>
38*cdf0e10cSrcweir#include <com/sun/star/security/CertificateCharacters.idl>
39*cdf0e10cSrcweir#include <com/sun/star/security/CertificateValidity.idl>
40*cdf0e10cSrcweir
41*cdf0e10cSrcweirmodule com { module sun { module star { module xml { module crypto {
42*cdf0e10cSrcweir
43*cdf0e10cSrcweir/**
44*cdf0e10cSrcweir * Interface of Security Environment
45*cdf0e10cSrcweir */
46*cdf0e10cSrcweirpublished interface XSecurityEnvironment : com::sun::star::uno::XInterface
47*cdf0e10cSrcweir{
48*cdf0e10cSrcweir    /**
49*cdf0e10cSrcweir     * Get personal certificate from the environment
50*cdf0e10cSrcweir     */
51*cdf0e10cSrcweir    sequence< com::sun::star::security::XCertificate > getPersonalCertificates() raises( com::sun::star::uno::SecurityException ) ;
52*cdf0e10cSrcweir
53*cdf0e10cSrcweir    /**
54*cdf0e10cSrcweir     * Get certificate from the environment by issuer name and serial number
55*cdf0e10cSrcweir     */
56*cdf0e10cSrcweir    com::sun::star::security::XCertificate getCertificate( [in] string issuerName, [in] sequence< byte > serialNumber ) raises( com::sun::star::uno::SecurityException ) ;
57*cdf0e10cSrcweir
58*cdf0e10cSrcweir    /**
59*cdf0e10cSrcweir     * build certificate path from a certain certificate
60*cdf0e10cSrcweir     */
61*cdf0e10cSrcweir    sequence< com::sun::star::security::XCertificate > buildCertificatePath( [in] com::sun::star::security::XCertificate beginCert ) raises( com::sun::star::uno::SecurityException ) ;
62*cdf0e10cSrcweir
63*cdf0e10cSrcweir    /**
64*cdf0e10cSrcweir     * Create certificate interface from raw DER encoded certificate
65*cdf0e10cSrcweir     */
66*cdf0e10cSrcweir    com::sun::star::security::XCertificate createCertificateFromRaw( [in] sequence< byte > rawCertificate ) raises( com::sun::star::uno::SecurityException ) ;
67*cdf0e10cSrcweir
68*cdf0e10cSrcweir    /**
69*cdf0e10cSrcweir     * Create certificate interface from a BASE64 encoded certificate.
70*cdf0e10cSrcweir     */
71*cdf0e10cSrcweir    com::sun::star::security::XCertificate createCertificateFromAscii( [in] string asciiCertificate ) raises( com::sun::star::uno::SecurityException ) ;
72*cdf0e10cSrcweir
73*cdf0e10cSrcweir    /**
74*cdf0e10cSrcweir      Verify a certificate.
75*cdf0e10cSrcweir
76*cdf0e10cSrcweir      The method provides a way to verify a certificate.
77*cdf0e10cSrcweir      @param xEECertificate
78*cdf0e10cSrcweir          The certificate which is to be validated.
79*cdf0e10cSrcweir
80*cdf0e10cSrcweir      @param intermediateCertificates
81*cdf0e10cSrcweir          Additional certificates which can be used by the method in constructing
82*cdf0e10cSrcweir          the certificate chain. The root certificate may also be contained. However,
83*cdf0e10cSrcweir          the implementation must check if the root certificate is indeed trusted by
84*cdf0e10cSrcweir          the user.
85*cdf0e10cSrcweir          All entries of the sequence must be non-null references.
86*cdf0e10cSrcweir
87*cdf0e10cSrcweir      @return
88*cdf0e10cSrcweir          The validation status will returned as a bit-wise long, please refer to
89*cdf0e10cSrcweir          CertificateValidity definition.
90*cdf0e10cSrcweir     */
91*cdf0e10cSrcweir    long verifyCertificate( [in] com::sun::star::security::XCertificate xEECertificate,
92*cdf0e10cSrcweir        [in] sequence< com::sun::star::security::XCertificate > intermediateCertificates)
93*cdf0e10cSrcweir        raises( com::sun::star::uno::SecurityException ) ;
94*cdf0e10cSrcweir
95*cdf0e10cSrcweir    /**
96*cdf0e10cSrcweir     * Get a certificate characters.
97*cdf0e10cSrcweir     *
98*cdf0e10cSrcweir     * The method provides a way to get certificate characters like:
99*cdf0e10cSrcweir     * 1. Whether or not the certificate have a private key in the user profile.
100*cdf0e10cSrcweir     * 2. Whether or not the certificate is a trusted certificate.
101*cdf0e10cSrcweir     * 3. Whether or not the certificate is a self-signed certificate.
102*cdf0e10cSrcweir     *
103*cdf0e10cSrcweir     * The certificate characters is defined as bit-wise long, please refer to
104*cdf0e10cSrcweir     * CertificateCharacters definition.
105*cdf0e10cSrcweir     */
106*cdf0e10cSrcweir    long getCertificateCharacters( [in] com::sun::star::security::XCertificate xCertificate ) raises( com::sun::star::uno::SecurityException ) ;
107*cdf0e10cSrcweir
108*cdf0e10cSrcweir    /**
109*cdf0e10cSrcweir     * Get the Environment detail infos
110*cdf0e10cSrcweir     */
111*cdf0e10cSrcweir    string getSecurityEnvironmentInformation ( );
112*cdf0e10cSrcweir
113*cdf0e10cSrcweir} ;
114*cdf0e10cSrcweir
115*cdf0e10cSrcweir} ; } ; } ; } ; } ;
116*cdf0e10cSrcweir
117*cdf0e10cSrcweir#endif
118*cdf0e10cSrcweir
119