You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
183 lines
6.6 KiB
183 lines
6.6 KiB
9 years ago
|
/* Copyright (c) 2012 The Chromium Authors. All rights reserved.
|
||
|
* Use of this source code is governed by a BSD-style license that can be
|
||
|
* found in the LICENSE file.
|
||
|
*/
|
||
|
|
||
|
/* From private/ppb_x509_certificate_private.idl,
|
||
|
* modified Wed Apr 11 17:11:26 2012.
|
||
|
*/
|
||
|
|
||
|
#ifndef PPAPI_C_PRIVATE_PPB_X509_CERTIFICATE_PRIVATE_H_
|
||
|
#define PPAPI_C_PRIVATE_PPB_X509_CERTIFICATE_PRIVATE_H_
|
||
|
|
||
|
#include "ppapi/c/pp_bool.h"
|
||
|
#include "ppapi/c/pp_instance.h"
|
||
|
#include "ppapi/c/pp_macros.h"
|
||
|
#include "ppapi/c/pp_resource.h"
|
||
|
#include "ppapi/c/pp_stdint.h"
|
||
|
#include "ppapi/c/pp_var.h"
|
||
|
|
||
|
#define PPB_X509CERTIFICATE_PRIVATE_INTERFACE_0_1 \
|
||
|
"PPB_X509Certificate_Private;0.1"
|
||
|
#define PPB_X509CERTIFICATE_PRIVATE_INTERFACE \
|
||
|
PPB_X509CERTIFICATE_PRIVATE_INTERFACE_0_1
|
||
|
|
||
|
/**
|
||
|
* @file
|
||
|
* This file defines the <code>PPB_X509Certificate_Private</code> interface for
|
||
|
* an X509 certificate.
|
||
|
*/
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @addtogroup Enums
|
||
|
* @{
|
||
|
*/
|
||
|
/**
|
||
|
* This enumeration corresponds to fields of an X509 certificate. Refer to
|
||
|
* <a href="http://www.ietf.org/rfc/rfc5280.txt>RFC 5280</a> for further
|
||
|
* documentation about particular fields.
|
||
|
*/
|
||
|
typedef enum {
|
||
|
/** This corresponds to a string (<code>PP_VARTYPE_STRING</code>). */
|
||
|
PP_X509CERTIFICATE_PRIVATE_ISSUER_COMMON_NAME = 0,
|
||
|
/** This corresponds to a string (<code>PP_VARTYPE_STRING</code>). */
|
||
|
PP_X509CERTIFICATE_PRIVATE_ISSUER_LOCALITY_NAME = 1,
|
||
|
/** This corresponds to a string (<code>PP_VARTYPE_STRING</code>). */
|
||
|
PP_X509CERTIFICATE_PRIVATE_ISSUER_STATE_OR_PROVINCE_NAME = 2,
|
||
|
/** This corresponds to a string (<code>PP_VARTYPE_STRING</code>). */
|
||
|
PP_X509CERTIFICATE_PRIVATE_ISSUER_COUNTRY_NAME = 3,
|
||
|
/** This corresponds to a string (<code>PP_VARTYPE_STRING</code>). */
|
||
|
PP_X509CERTIFICATE_PRIVATE_ISSUER_ORGANIZATION_NAME = 4,
|
||
|
/** This corresponds to a string (<code>PP_VARTYPE_STRING</code>). */
|
||
|
PP_X509CERTIFICATE_PRIVATE_ISSUER_ORGANIZATION_UNIT_NAME = 5,
|
||
|
/**
|
||
|
* Note: This field is unimplemented and will return
|
||
|
* <code>PP_VARTYPE_NULL</code>.
|
||
|
*/
|
||
|
PP_X509CERTIFICATE_PRIVATE_ISSUER_UNIQUE_ID = 6,
|
||
|
/** This corresponds to a string (<code>PP_VARTYPE_STRING</code>). */
|
||
|
PP_X509CERTIFICATE_PRIVATE_SUBJECT_COMMON_NAME = 7,
|
||
|
/** This corresponds to a string (<code>PP_VARTYPE_STRING</code>). */
|
||
|
PP_X509CERTIFICATE_PRIVATE_SUBJECT_LOCALITY_NAME = 8,
|
||
|
/** This corresponds to a string (<code>PP_VARTYPE_STRING</code>). */
|
||
|
PP_X509CERTIFICATE_PRIVATE_SUBJECT_STATE_OR_PROVINCE_NAME = 9,
|
||
|
/** This corresponds to a string (<code>PP_VARTYPE_STRING</code>). */
|
||
|
PP_X509CERTIFICATE_PRIVATE_SUBJECT_COUNTRY_NAME = 10,
|
||
|
/** This corresponds to a string (<code>PP_VARTYPE_STRING</code>). */
|
||
|
PP_X509CERTIFICATE_PRIVATE_SUBJECT_ORGANIZATION_NAME = 11,
|
||
|
/** This corresponds to a string (<code>PP_VARTYPE_STRING</code>). */
|
||
|
PP_X509CERTIFICATE_PRIVATE_SUBJECT_ORGANIZATION_UNIT_NAME = 12,
|
||
|
/**
|
||
|
* Note: This field is unimplemented and will return
|
||
|
* <code>PP_VARTYPE_NULL</code>.
|
||
|
*/
|
||
|
PP_X509CERTIFICATE_PRIVATE_SUBJECT_UNIQUE_ID = 13,
|
||
|
/**
|
||
|
* Note: This field is unimplemented and will return
|
||
|
* <code>PP_VARTYPE_NULL</code>.
|
||
|
*/
|
||
|
PP_X509CERTIFICATE_PRIVATE_VERSION = 14,
|
||
|
/**
|
||
|
* This corresponds to a byte array (<code>PP_VARTYPE_ARRAY_BUFFER</code>).
|
||
|
* The serial number may include a leading 0.
|
||
|
*/
|
||
|
PP_X509CERTIFICATE_PRIVATE_SERIAL_NUMBER = 15,
|
||
|
/**
|
||
|
* Note: This field is unimplemented and will return
|
||
|
* <code>PP_VARTYPE_NULL</code>.
|
||
|
*/
|
||
|
PP_X509CERTIFICATE_PRIVATE_SIGNATURE_ALGORITHM_OID = 16,
|
||
|
/**
|
||
|
* Note: This field is unimplemented and will return
|
||
|
* <code>PP_VARTYPE_NULL</code>.
|
||
|
*/
|
||
|
PP_X509CERTIFICATE_PRIVATE_SIGNATURE_ALGORITHM_PARAMATERS_RAW = 17,
|
||
|
/**
|
||
|
* This corresponds to a double (<code>PP_VARTYPE_DOUBLE</code>) which
|
||
|
* can be cast to a <code>PP_TIME</code>.
|
||
|
*/
|
||
|
PP_X509CERTIFICATE_PRIVATE_VALIDITY_NOT_BEFORE = 18,
|
||
|
/**
|
||
|
* This corresponds to a double (<code>PP_VARTYPE_DOUBLE</code>) which
|
||
|
* can be cast to a <code>PP_TIME</code>.
|
||
|
*/
|
||
|
PP_X509CERTIFICATE_PRIVATE_VALIDITY_NOT_AFTER = 19,
|
||
|
/** This corresponds to a string (<code>PP_VARTYPE_STRING</code>). */
|
||
|
PP_X509CERTIFICATE_PRIVATE_SUBJECT_PUBLIC_KEY_ALGORITHM_OID = 20,
|
||
|
/**
|
||
|
* Note: This field is unimplemented and will return
|
||
|
* <code>PP_VARTYPE_NULL</code>.
|
||
|
*/
|
||
|
PP_X509CERTIFICATE_PRIVATE_SUBJECT_PUBLIC_KEY = 21,
|
||
|
/**
|
||
|
* This corresponds to a byte array (<code>PP_VARTYPE_ARRAY_BUFFER</code>).
|
||
|
* This is the DER-encoded representation of the certificate.
|
||
|
*/
|
||
|
PP_X509CERTIFICATE_PRIVATE_RAW = 22,
|
||
|
/** This corresponds to a string (<code>PP_VARTYPE_STRING</code>). */
|
||
|
PP_X509CERTIFICATE_PRIVATE_ISSUER_DISTINGUISHED_NAME = 23,
|
||
|
/** This corresponds to a string (<code>PP_VARTYPE_STRING</code>). */
|
||
|
PP_X509CERTIFICATE_PRIVATE_SUBJECT_DISTINGUISHED_NAME = 24
|
||
|
} PP_X509Certificate_Private_Field;
|
||
|
PP_COMPILE_ASSERT_SIZE_IN_BYTES(PP_X509Certificate_Private_Field, 4);
|
||
|
|
||
|
/**
|
||
|
* This enumeration defines the different possible values for X5O9 certificate
|
||
|
* versions as returned by:
|
||
|
* <code>GetField(resource, PP_X509CERTIFICATE_PRIVATE_VERSION)</code>.
|
||
|
*/
|
||
|
typedef enum {
|
||
|
PP_X509CERTIFICATE_PRIVATE_V1 = 0,
|
||
|
PP_X509CERTIFICATE_PRIVATE_V2 = 1,
|
||
|
PP_X509CERTIFICATE_PRIVATE_V3 = 2
|
||
|
} PPB_X509Certificate_Private_Version;
|
||
|
PP_COMPILE_ASSERT_SIZE_IN_BYTES(PPB_X509Certificate_Private_Version, 4);
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* @addtogroup Interfaces
|
||
|
* @{
|
||
|
*/
|
||
|
/**
|
||
|
* The <code>PPB_X509Certificate_Private</code> interface provides access to
|
||
|
* the fields of an X509 certificate.
|
||
|
*/
|
||
|
struct PPB_X509Certificate_Private_0_1 {
|
||
|
/**
|
||
|
* Allocates a <code>PPB_X509Certificate_Private</code> resource.
|
||
|
* <code>Initialize()</code> must be called before using the certificate.
|
||
|
*/
|
||
|
PP_Resource (*Create)(PP_Instance instance);
|
||
|
/**
|
||
|
* Returns <code>PP_TRUE</code> if a given resource is a
|
||
|
* <code>PPB_X509Certificate_Private</code>.
|
||
|
*/
|
||
|
PP_Bool (*IsX509CertificatePrivate)(PP_Resource resource);
|
||
|
/**
|
||
|
* Initializes a <code>PPB_X509Certificate_Private</code> from the DER-encoded
|
||
|
* representation. |bytes| should represent only a single certificate.
|
||
|
* <code>PP_FALSE</code> is returned if |bytes| is not a valid DER-encoding of
|
||
|
* a certificate. Note: Flash requires this to be synchronous.
|
||
|
*/
|
||
|
PP_Bool (*Initialize)(PP_Resource resource,
|
||
|
const char* bytes,
|
||
|
uint32_t length);
|
||
|
/**
|
||
|
* Get a field of the X509Certificate as a <code>PP_Var</code>. A null
|
||
|
* <code>PP_Var</code> is returned if the field is unavailable.
|
||
|
*/
|
||
|
struct PP_Var (*GetField)(PP_Resource resource,
|
||
|
PP_X509Certificate_Private_Field field);
|
||
|
};
|
||
|
|
||
|
typedef struct PPB_X509Certificate_Private_0_1 PPB_X509Certificate_Private;
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
#endif /* PPAPI_C_PRIVATE_PPB_X509_CERTIFICATE_PRIVATE_H_ */
|
||
|
|