str_meth.c 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280
  1. /* crypto/store/str_meth.c -*- mode:C; c-file-style: "eay" -*- */
  2. /*
  3. * Written by Richard Levitte (richard@levitte.org) for the OpenSSL project
  4. * 2003.
  5. */
  6. /* ====================================================================
  7. * Copyright (c) 2003 The OpenSSL Project. All rights reserved.
  8. *
  9. * Redistribution and use in source and binary forms, with or without
  10. * modification, are permitted provided that the following conditions
  11. * are met:
  12. *
  13. * 1. Redistributions of source code must retain the above copyright
  14. * notice, this list of conditions and the following disclaimer.
  15. *
  16. * 2. Redistributions in binary form must reproduce the above copyright
  17. * notice, this list of conditions and the following disclaimer in
  18. * the documentation and/or other materials provided with the
  19. * distribution.
  20. *
  21. * 3. All advertising materials mentioning features or use of this
  22. * software must display the following acknowledgment:
  23. * "This product includes software developed by the OpenSSL Project
  24. * for use in the OpenSSL Toolkit. (http://www.openssl.org/)"
  25. *
  26. * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
  27. * endorse or promote products derived from this software without
  28. * prior written permission. For written permission, please contact
  29. * openssl-core@openssl.org.
  30. *
  31. * 5. Products derived from this software may not be called "OpenSSL"
  32. * nor may "OpenSSL" appear in their names without prior written
  33. * permission of the OpenSSL Project.
  34. *
  35. * 6. Redistributions of any form whatsoever must retain the following
  36. * acknowledgment:
  37. * "This product includes software developed by the OpenSSL Project
  38. * for use in the OpenSSL Toolkit (http://www.openssl.org/)"
  39. *
  40. * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
  41. * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  42. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
  43. * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE OpenSSL PROJECT OR
  44. * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  45. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  46. * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
  47. * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  48. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
  49. * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  50. * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
  51. * OF THE POSSIBILITY OF SUCH DAMAGE.
  52. * ====================================================================
  53. *
  54. * This product includes cryptographic software written by Eric Young
  55. * (eay@cryptsoft.com). This product includes software written by Tim
  56. * Hudson (tjh@cryptsoft.com).
  57. *
  58. */
  59. #include <string.h>
  60. #include <openssl/buffer.h>
  61. #include "str_locl.h"
  62. STORE_METHOD *STORE_create_method(char *name)
  63. {
  64. STORE_METHOD *store_method =
  65. (STORE_METHOD *)OPENSSL_malloc(sizeof(STORE_METHOD));
  66. if (store_method) {
  67. memset(store_method, 0, sizeof(*store_method));
  68. store_method->name = BUF_strdup(name);
  69. }
  70. return store_method;
  71. }
  72. /*
  73. * BIG FSCKING WARNING!!!! If you use this on a statically allocated method
  74. * (that is, it hasn't been allocated using STORE_create_method(), you
  75. * deserve anything Murphy can throw at you and more! You have been warned.
  76. */
  77. void STORE_destroy_method(STORE_METHOD *store_method)
  78. {
  79. if (!store_method)
  80. return;
  81. OPENSSL_free(store_method->name);
  82. store_method->name = NULL;
  83. OPENSSL_free(store_method);
  84. }
  85. int STORE_method_set_initialise_function(STORE_METHOD *sm,
  86. STORE_INITIALISE_FUNC_PTR init_f)
  87. {
  88. sm->init = init_f;
  89. return 1;
  90. }
  91. int STORE_method_set_cleanup_function(STORE_METHOD *sm,
  92. STORE_CLEANUP_FUNC_PTR clean_f)
  93. {
  94. sm->clean = clean_f;
  95. return 1;
  96. }
  97. int STORE_method_set_generate_function(STORE_METHOD *sm,
  98. STORE_GENERATE_OBJECT_FUNC_PTR
  99. generate_f)
  100. {
  101. sm->generate_object = generate_f;
  102. return 1;
  103. }
  104. int STORE_method_set_get_function(STORE_METHOD *sm,
  105. STORE_GET_OBJECT_FUNC_PTR get_f)
  106. {
  107. sm->get_object = get_f;
  108. return 1;
  109. }
  110. int STORE_method_set_store_function(STORE_METHOD *sm,
  111. STORE_STORE_OBJECT_FUNC_PTR store_f)
  112. {
  113. sm->store_object = store_f;
  114. return 1;
  115. }
  116. int STORE_method_set_modify_function(STORE_METHOD *sm,
  117. STORE_MODIFY_OBJECT_FUNC_PTR modify_f)
  118. {
  119. sm->modify_object = modify_f;
  120. return 1;
  121. }
  122. int STORE_method_set_revoke_function(STORE_METHOD *sm,
  123. STORE_HANDLE_OBJECT_FUNC_PTR revoke_f)
  124. {
  125. sm->revoke_object = revoke_f;
  126. return 1;
  127. }
  128. int STORE_method_set_delete_function(STORE_METHOD *sm,
  129. STORE_HANDLE_OBJECT_FUNC_PTR delete_f)
  130. {
  131. sm->delete_object = delete_f;
  132. return 1;
  133. }
  134. int STORE_method_set_list_start_function(STORE_METHOD *sm,
  135. STORE_START_OBJECT_FUNC_PTR
  136. list_start_f)
  137. {
  138. sm->list_object_start = list_start_f;
  139. return 1;
  140. }
  141. int STORE_method_set_list_next_function(STORE_METHOD *sm,
  142. STORE_NEXT_OBJECT_FUNC_PTR
  143. list_next_f)
  144. {
  145. sm->list_object_next = list_next_f;
  146. return 1;
  147. }
  148. int STORE_method_set_list_end_function(STORE_METHOD *sm,
  149. STORE_END_OBJECT_FUNC_PTR list_end_f)
  150. {
  151. sm->list_object_end = list_end_f;
  152. return 1;
  153. }
  154. int STORE_method_set_update_store_function(STORE_METHOD *sm,
  155. STORE_GENERIC_FUNC_PTR update_f)
  156. {
  157. sm->update_store = update_f;
  158. return 1;
  159. }
  160. int STORE_method_set_lock_store_function(STORE_METHOD *sm,
  161. STORE_GENERIC_FUNC_PTR lock_f)
  162. {
  163. sm->lock_store = lock_f;
  164. return 1;
  165. }
  166. int STORE_method_set_unlock_store_function(STORE_METHOD *sm,
  167. STORE_GENERIC_FUNC_PTR unlock_f)
  168. {
  169. sm->unlock_store = unlock_f;
  170. return 1;
  171. }
  172. int STORE_method_set_ctrl_function(STORE_METHOD *sm,
  173. STORE_CTRL_FUNC_PTR ctrl_f)
  174. {
  175. sm->ctrl = ctrl_f;
  176. return 1;
  177. }
  178. STORE_INITIALISE_FUNC_PTR STORE_method_get_initialise_function(STORE_METHOD
  179. *sm)
  180. {
  181. return sm->init;
  182. }
  183. STORE_CLEANUP_FUNC_PTR STORE_method_get_cleanup_function(STORE_METHOD *sm)
  184. {
  185. return sm->clean;
  186. }
  187. STORE_GENERATE_OBJECT_FUNC_PTR STORE_method_get_generate_function(STORE_METHOD
  188. *sm)
  189. {
  190. return sm->generate_object;
  191. }
  192. STORE_GET_OBJECT_FUNC_PTR STORE_method_get_get_function(STORE_METHOD *sm)
  193. {
  194. return sm->get_object;
  195. }
  196. STORE_STORE_OBJECT_FUNC_PTR STORE_method_get_store_function(STORE_METHOD *sm)
  197. {
  198. return sm->store_object;
  199. }
  200. STORE_MODIFY_OBJECT_FUNC_PTR STORE_method_get_modify_function(STORE_METHOD
  201. *sm)
  202. {
  203. return sm->modify_object;
  204. }
  205. STORE_HANDLE_OBJECT_FUNC_PTR STORE_method_get_revoke_function(STORE_METHOD
  206. *sm)
  207. {
  208. return sm->revoke_object;
  209. }
  210. STORE_HANDLE_OBJECT_FUNC_PTR STORE_method_get_delete_function(STORE_METHOD
  211. *sm)
  212. {
  213. return sm->delete_object;
  214. }
  215. STORE_START_OBJECT_FUNC_PTR STORE_method_get_list_start_function(STORE_METHOD
  216. *sm)
  217. {
  218. return sm->list_object_start;
  219. }
  220. STORE_NEXT_OBJECT_FUNC_PTR STORE_method_get_list_next_function(STORE_METHOD
  221. *sm)
  222. {
  223. return sm->list_object_next;
  224. }
  225. STORE_END_OBJECT_FUNC_PTR STORE_method_get_list_end_function(STORE_METHOD *sm)
  226. {
  227. return sm->list_object_end;
  228. }
  229. STORE_GENERIC_FUNC_PTR STORE_method_get_update_store_function(STORE_METHOD
  230. *sm)
  231. {
  232. return sm->update_store;
  233. }
  234. STORE_GENERIC_FUNC_PTR STORE_method_get_lock_store_function(STORE_METHOD *sm)
  235. {
  236. return sm->lock_store;
  237. }
  238. STORE_GENERIC_FUNC_PTR STORE_method_get_unlock_store_function(STORE_METHOD
  239. *sm)
  240. {
  241. return sm->unlock_store;
  242. }
  243. STORE_CTRL_FUNC_PTR STORE_method_get_ctrl_function(STORE_METHOD *sm)
  244. {
  245. return sm->ctrl;
  246. }