Fix more error codes.
[openssl.git] / crypto / store / store.h
index 5dba567c573afa3e61726373ef50d3cf5aab4586..64583377a94a8f9d52fe0281776d9bdc7643dc90 100644 (file)
 #ifndef HEADER_STORE_H
 #define HEADER_STORE_H
 
-#include <openssl/x509.h>
+#include <openssl/ossl_typ.h>
+#ifndef OPENSSL_NO_DEPRECATED
 #include <openssl/evp.h>
 #include <openssl/bn.h>
+#include <openssl/x509.h>
+#endif
 
 #ifdef  __cplusplus
 extern "C" {
 #endif
 
-/* The STORE type is a per-store context that holds all the necessary data
-   to perform all the supported storage operations. */
-typedef struct store_st STORE;
-
-/* All instances of STORE have a reference to a method structure, which is a
-   ordered vector of functions that implement the lower level things to do.
-   There is an instruction on the implementation further down, in the section
-   for method implementors. */
-typedef struct store_method_st STORE_METHOD;
+/* Already defined in ossl_typ.h */
+/* typedef struct store_st STORE; */
+/* typedef struct store_method_st STORE_METHOD; */
 
 
 /* All the following functions return 0, a negative number or NULL on error.
@@ -84,13 +81,14 @@ typedef struct store_method_st STORE_METHOD;
 
 /* Creators and destructor.   */
 STORE *STORE_new_method(const STORE_METHOD *method);
+STORE *STORE_new_engine(ENGINE *engine);
 void STORE_free(STORE *ui);
 
 
 /* Give a user interface parametrised control commands.  This can be used to
    send down an integer, a data pointer or a function pointer, as well as
    be used to get information from a STORE. */
-int STORE_ctrl(STORE *store, int cmd, long i, void *p, void (*f)());
+int STORE_ctrl(STORE *store, int cmd, long i, void *p, void (*f)(void));
 
 /* A control to set the directory with keys and certificates.  Used by the
    built-in directory level method. */
@@ -122,6 +120,7 @@ const STORE_METHOD *STORE_set_method(STORE *store, const STORE_METHOD *meth);
    and is of course volatile.  It's used by other methods that have an in-memory
    cache. */
 const STORE_METHOD *STORE_Memory(void);
+#if 0 /* Not yet implemented */
 /* This is the directory store.  It does everything except revoking and updating,
    and uses STORE_Memory() to cache things in memory. */
 const STORE_METHOD *STORE_Directory(void);
@@ -129,7 +128,7 @@ const STORE_METHOD *STORE_Directory(void);
    and uses STORE_Memory() to cache things in memory.  Certificates are added
    to it with the store operation, and it will only get cached certificates. */
 const STORE_METHOD *STORE_File(void);
-
+#endif
 
 /* Store functions take a type code for the type of data they should store
    or fetch */
@@ -220,7 +219,7 @@ typedef struct STORE_OBJECT_st
                BUF_MEM *arbitrary;
                } data;
        } STORE_OBJECT;
-DECLARE_STACK_OF(STORE_OBJECT);
+DECLARE_STACK_OF(STORE_OBJECT)
 STORE_OBJECT *STORE_OBJECT_new(void);
 void STORE_OBJECT_free(STORE_OBJECT *data);
 
@@ -330,11 +329,11 @@ typedef int (*STORE_HANDLE_OBJECT_FUNC_PTR)(STORE *, STORE_OBJECT_TYPES type, OP
 typedef int (*STORE_STORE_OBJECT_FUNC_PTR)(STORE *, STORE_OBJECT_TYPES type, STORE_OBJECT *data, OPENSSL_ITEM attributes[], OPENSSL_ITEM parameters[]);
 typedef int (*STORE_MODIFY_OBJECT_FUNC_PTR)(STORE *, STORE_OBJECT_TYPES type, OPENSSL_ITEM search_attributes[], OPENSSL_ITEM add_attributes[], OPENSSL_ITEM modify_attributes[], OPENSSL_ITEM delete_attributes[], OPENSSL_ITEM parameters[]);
 typedef int (*STORE_GENERIC_FUNC_PTR)(STORE *, OPENSSL_ITEM attributes[], OPENSSL_ITEM parameters[]);
-typedef int (*STORE_CTRL_FUNC_PTR)(STORE *, int cmd, long l, void *p, void (*f)());
+typedef int (*STORE_CTRL_FUNC_PTR)(STORE *, int cmd, long l, void *p, void (*f)(void));
 
-int STORE_method_set_initialise_function(STORE_METHOD *sm, STORE_INITIALISE_FUNC_PTR gen_f);
-int STORE_method_set_cleanup_function(STORE_METHOD *sm, STORE_CLEANUP_FUNC_PTR gen_f);
-int STORE_method_set_generate_function(STORE_METHOD *sm, STORE_GENERATE_OBJECT_FUNC_PTR gen_f);
+int STORE_method_set_initialise_function(STORE_METHOD *sm, STORE_INITIALISE_FUNC_PTR init_f);
+int STORE_method_set_cleanup_function(STORE_METHOD *sm, STORE_CLEANUP_FUNC_PTR clean_f);
+int STORE_method_set_generate_function(STORE_METHOD *sm, STORE_GENERATE_OBJECT_FUNC_PTR generate_f);
 int STORE_method_set_get_function(STORE_METHOD *sm, STORE_GET_OBJECT_FUNC_PTR get_f);
 int STORE_method_set_store_function(STORE_METHOD *sm, STORE_STORE_OBJECT_FUNC_PTR store_f);
 int STORE_method_set_modify_function(STORE_METHOD *sm, STORE_MODIFY_OBJECT_FUNC_PTR store_f);
@@ -410,6 +409,9 @@ int STORE_ATTR_INFO_modify_number(STORE_ATTR_INFO *attrs, STORE_ATTR_TYPES code,
 /* Compare on basis of a bit pattern formed by the STORE_ATTR_TYPES values
    in each contained attribute. */
 int STORE_ATTR_INFO_compare(STORE_ATTR_INFO *a, STORE_ATTR_INFO *b);
+/* Check if the set of attributes in a is within the range of attributes
+   set in b. */
+int STORE_ATTR_INFO_in_range(STORE_ATTR_INFO *a, STORE_ATTR_INFO *b);
 /* Check if the set of attributes in a are also set in b. */
 int STORE_ATTR_INFO_in(STORE_ATTR_INFO *a, STORE_ATTR_INFO *b);
 /* Same as STORE_ATTR_INFO_in(), but also checks the attribute values. */
@@ -427,10 +429,11 @@ void ERR_load_STORE_strings(void);
 /* Function codes. */
 #define STORE_F_MEM_DELETE                              134
 #define STORE_F_MEM_GENERATE                            135
+#define STORE_F_MEM_LIST_END                            168
 #define STORE_F_MEM_LIST_NEXT                           136
 #define STORE_F_MEM_LIST_START                          137
+#define STORE_F_MEM_MODIFY                              169
 #define STORE_F_MEM_STORE                               138
-#define STORE_F_STORE_ARBITRARY                                 157
 #define STORE_F_STORE_ATTR_INFO_GET0_CSTR               139
 #define STORE_F_STORE_ATTR_INFO_GET0_DN                         140
 #define STORE_F_STORE_ATTR_INFO_GET0_NUMBER             141
@@ -443,8 +446,8 @@ void ERR_load_STORE_strings(void);
 #define STORE_F_STORE_ATTR_INFO_SET_DN                  148
 #define STORE_F_STORE_ATTR_INFO_SET_NUMBER              149
 #define STORE_F_STORE_ATTR_INFO_SET_SHA1STR             150
-#define STORE_F_STORE_CERTIFICATE                       100
-#define STORE_F_STORE_CRL                               101
+#define STORE_F_STORE_CERTIFICATE                       170
+#define STORE_F_STORE_CTRL                              161
 #define STORE_F_STORE_DELETE_ARBITRARY                  158
 #define STORE_F_STORE_DELETE_CERTIFICATE                102
 #define STORE_F_STORE_DELETE_CRL                        103
@@ -475,16 +478,27 @@ void ERR_load_STORE_strings(void);
 #define STORE_F_STORE_LIST_PUBLIC_KEY_ENDP              156
 #define STORE_F_STORE_LIST_PUBLIC_KEY_NEXT              124
 #define STORE_F_STORE_LIST_PUBLIC_KEY_START             125
+#define STORE_F_STORE_MODIFY_ARBITRARY                  162
+#define STORE_F_STORE_MODIFY_CERTIFICATE                163
+#define STORE_F_STORE_MODIFY_CRL                        164
+#define STORE_F_STORE_MODIFY_NUMBER                     165
+#define STORE_F_STORE_MODIFY_PRIVATE_KEY                166
+#define STORE_F_STORE_MODIFY_PUBLIC_KEY                         167
 #define STORE_F_STORE_NEW_ENGINE                        133
 #define STORE_F_STORE_NEW_METHOD                        132
-#define STORE_F_STORE_NUMBER                            126
 #define STORE_F_STORE_PARSE_ATTRS_END                   151
+#define STORE_F_STORE_PARSE_ATTRS_ENDP                  172
 #define STORE_F_STORE_PARSE_ATTRS_NEXT                  152
-#define STORE_F_STORE_PRIVATE_KEY                       127
-#define STORE_F_STORE_PUBLIC_KEY                        128
+#define STORE_F_STORE_PARSE_ATTRS_START                         171
 #define STORE_F_STORE_REVOKE_CERTIFICATE                129
 #define STORE_F_STORE_REVOKE_PRIVATE_KEY                130
 #define STORE_F_STORE_REVOKE_PUBLIC_KEY                         131
+#define STORE_F_STORE_STORE_ARBITRARY                   157
+#define STORE_F_STORE_STORE_CERTIFICATE                         100
+#define STORE_F_STORE_STORE_CRL                                 101
+#define STORE_F_STORE_STORE_NUMBER                      126
+#define STORE_F_STORE_STORE_PRIVATE_KEY                         127
+#define STORE_F_STORE_STORE_PUBLIC_KEY                  128
 
 /* Reason codes. */
 #define STORE_R_ALREADY_HAS_A_VALUE                     127
@@ -500,6 +514,12 @@ void ERR_load_STORE_strings(void);
 #define STORE_R_FAILED_GETTING_NUMBER                   107
 #define STORE_R_FAILED_LISTING_CERTIFICATES             108
 #define STORE_R_FAILED_LISTING_KEYS                     109
+#define STORE_R_FAILED_MODIFYING_ARBITRARY              138
+#define STORE_R_FAILED_MODIFYING_CERTIFICATE            139
+#define STORE_R_FAILED_MODIFYING_CRL                    140
+#define STORE_R_FAILED_MODIFYING_NUMBER                         141
+#define STORE_R_FAILED_MODIFYING_PRIVATE_KEY            142
+#define STORE_R_FAILED_MODIFYING_PUBLIC_KEY             143
 #define STORE_R_FAILED_REVOKING_CERTIFICATE             110
 #define STORE_R_FAILED_REVOKING_KEY                     111
 #define STORE_R_FAILED_STORING_ARBITRARY                134
@@ -507,6 +527,7 @@ void ERR_load_STORE_strings(void);
 #define STORE_R_FAILED_STORING_KEY                      113
 #define STORE_R_FAILED_STORING_NUMBER                   114
 #define STORE_R_NOT_IMPLEMENTED                                 128
+#define STORE_R_NO_CONTROL_FUNCTION                     144
 #define STORE_R_NO_DELETE_ARBITRARY_FUNCTION            135
 #define STORE_R_NO_DELETE_NUMBER_FUNCTION               115
 #define STORE_R_NO_DELETE_OBJECT_FUNCTION               116
@@ -519,6 +540,7 @@ void ERR_load_STORE_strings(void);
 #define STORE_R_NO_LIST_OBJECT_END_FUNCTION             121
 #define STORE_R_NO_LIST_OBJECT_NEXT_FUNCTION            122
 #define STORE_R_NO_LIST_OBJECT_START_FUNCTION           123
+#define STORE_R_NO_MODIFY_OBJECT_FUNCTION               145
 #define STORE_R_NO_REVOKE_OBJECT_FUNCTION               124
 #define STORE_R_NO_STORE                                129
 #define STORE_R_NO_STORE_OBJECT_ARBITRARY_FUNCTION      137