1*d1766043SAndrew Rist/************************************************************** 2*d1766043SAndrew Rist * 3*d1766043SAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one 4*d1766043SAndrew Rist * or more contributor license agreements. See the NOTICE file 5*d1766043SAndrew Rist * distributed with this work for additional information 6*d1766043SAndrew Rist * regarding copyright ownership. The ASF licenses this file 7*d1766043SAndrew Rist * to you under the Apache License, Version 2.0 (the 8*d1766043SAndrew Rist * "License"); you may not use this file except in compliance 9*d1766043SAndrew Rist * with the License. You may obtain a copy of the License at 10*d1766043SAndrew Rist * 11*d1766043SAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0 12*d1766043SAndrew Rist * 13*d1766043SAndrew Rist * Unless required by applicable law or agreed to in writing, 14*d1766043SAndrew Rist * software distributed under the License is distributed on an 15*d1766043SAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16*d1766043SAndrew Rist * KIND, either express or implied. See the License for the 17*d1766043SAndrew Rist * specific language governing permissions and limitations 18*d1766043SAndrew Rist * under the License. 19*d1766043SAndrew Rist * 20*d1766043SAndrew Rist *************************************************************/ 21*d1766043SAndrew Rist 22*d1766043SAndrew Rist 23cdf0e10cSrcweir 24cdf0e10cSrcweir#ifndef __com_sun_star_security_XCertificate_idl_ 25cdf0e10cSrcweir#define __com_sun_star_security_XCertificate_idl_ 26cdf0e10cSrcweir 27cdf0e10cSrcweir#include <com/sun/star/uno/XInterface.idl> 28cdf0e10cSrcweir#include <com/sun/star/util/DateTime.idl> 29cdf0e10cSrcweir#include <com/sun/star/security/XCertificateExtension.idl> 30cdf0e10cSrcweir 31cdf0e10cSrcweirmodule com { module sun { module star { module security { 32cdf0e10cSrcweir 33cdf0e10cSrcweir/** 34cdf0e10cSrcweir * Interface of a PKI Certificate 35cdf0e10cSrcweir * 36cdf0e10cSrcweir * <p>This interface represents a x509 certificate.</p> 37cdf0e10cSrcweir */ 38cdf0e10cSrcweirpublished interface XCertificate : com::sun::star::uno::XInterface 39cdf0e10cSrcweir{ 40cdf0e10cSrcweir /** 41cdf0e10cSrcweir * the version number attribute of the certificate. 42cdf0e10cSrcweir */ 43cdf0e10cSrcweir [attribute, readonly] short Version ; 44cdf0e10cSrcweir 45cdf0e10cSrcweir /** 46cdf0e10cSrcweir * the serial number attribute of the certificate. 47cdf0e10cSrcweir */ 48cdf0e10cSrcweir [attribute, readonly] sequence< byte > SerialNumber ; 49cdf0e10cSrcweir 50cdf0e10cSrcweir /** 51cdf0e10cSrcweir * the issuer name attribute of the certificate. 52cdf0e10cSrcweir */ 53cdf0e10cSrcweir [attribute, readonly] string IssuerName ; 54cdf0e10cSrcweir 55cdf0e10cSrcweir /** 56cdf0e10cSrcweir * the subject name attribute of the certificate. 57cdf0e10cSrcweir */ 58cdf0e10cSrcweir [attribute, readonly] string SubjectName ; 59cdf0e10cSrcweir 60cdf0e10cSrcweir /** 61cdf0e10cSrcweir * the validity NotBefore date attribute of the certificate. 62cdf0e10cSrcweir */ 63cdf0e10cSrcweir [attribute, readonly] com::sun::star::util::DateTime NotValidBefore ; 64cdf0e10cSrcweir 65cdf0e10cSrcweir /** 66cdf0e10cSrcweir * the validity NotAfter date attribute of the certificate. 67cdf0e10cSrcweir */ 68cdf0e10cSrcweir [attribute, readonly] com::sun::star::util::DateTime NotValidAfter ; 69cdf0e10cSrcweir 70cdf0e10cSrcweir /** 71cdf0e10cSrcweir * the issuer unique ID attribute of the certificate. 72cdf0e10cSrcweir */ 73cdf0e10cSrcweir [attribute, readonly] sequence< byte > IssuerUniqueID ; 74cdf0e10cSrcweir 75cdf0e10cSrcweir /** 76cdf0e10cSrcweir * the subject unique ID attribute of the certificate. 77cdf0e10cSrcweir */ 78cdf0e10cSrcweir [attribute, readonly] sequence< byte > SubjectUniqueID ; 79cdf0e10cSrcweir 80cdf0e10cSrcweir /** 81cdf0e10cSrcweir * all extensions of a certificate. 82cdf0e10cSrcweir */ 83cdf0e10cSrcweir [attribute, readonly] sequence< XCertificateExtension > Extensions ; 84cdf0e10cSrcweir 85cdf0e10cSrcweir /** 86cdf0e10cSrcweir * the DER encoded form of the certificate 87cdf0e10cSrcweir */ 88cdf0e10cSrcweir [attribute, readonly] sequence< byte > Encoded ; 89cdf0e10cSrcweir 90cdf0e10cSrcweir /** 91cdf0e10cSrcweir * the algorithm of the subject public key 92cdf0e10cSrcweir */ 93cdf0e10cSrcweir [attribute, readonly] string SubjectPublicKeyAlgorithm; 94cdf0e10cSrcweir 95cdf0e10cSrcweir /** 96cdf0e10cSrcweir * the value of the subject public key 97cdf0e10cSrcweir */ 98cdf0e10cSrcweir [attribute, readonly] sequence< byte > SubjectPublicKeyValue; 99cdf0e10cSrcweir 100cdf0e10cSrcweir /** 101cdf0e10cSrcweir * the signature algorithm 102cdf0e10cSrcweir */ 103cdf0e10cSrcweir [attribute, readonly] string SignatureAlgorithm; 104cdf0e10cSrcweir 105cdf0e10cSrcweir /** 106cdf0e10cSrcweir * the SHA1 thumbprint 107cdf0e10cSrcweir */ 108cdf0e10cSrcweir [attribute, readonly] sequence< byte > SHA1Thumbprint; 109cdf0e10cSrcweir 110cdf0e10cSrcweir /** 111cdf0e10cSrcweir * the MD5 thumbprint 112cdf0e10cSrcweir */ 113cdf0e10cSrcweir [attribute, readonly] sequence< byte > MD5Thumbprint; 114cdf0e10cSrcweir 115cdf0e10cSrcweir /** 116cdf0e10cSrcweir * Find a extension with a object identifier. 117cdf0e10cSrcweir */ 118cdf0e10cSrcweir XCertificateExtension findCertificateExtension( [in]sequence< byte > oid ) ; 119cdf0e10cSrcweir 120cdf0e10cSrcweir /** 121cdf0e10cSrcweir * get the certificate usage 122cdf0e10cSrcweir */ 123cdf0e10cSrcweir long getCertificateUsage(); 124cdf0e10cSrcweir} ; 125cdf0e10cSrcweir 126cdf0e10cSrcweir} ; } ; } ; } ; 127cdf0e10cSrcweir 128cdf0e10cSrcweir#endif 129cdf0e10cSrcweir 130