OSSL_METHOD_STORE.pod 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. =pod
  2. =head1 NAME
  3. OSSL_METHOD_STORE, ossl_method_store_new, ossl_method_store_free,
  4. ossl_method_store_init, ossl_method_store_cleanup,
  5. ossl_method_store_add, ossl_method_store_remove, ossl_method_store_fetch,
  6. ossl_method_store_cache_get, ossl_method_store_cache_set,
  7. ossl_method_store_flush_cache
  8. - implementation method store and query
  9. =head1 SYNOPSIS
  10. #include "internal/property.h"
  11. typedef struct ossl_method_store_st OSSL_METHOD_STORE;
  12. OSSL_METHOD_STORE *ossl_method_store_new(OSSL_LIB_CTX *ctx);
  13. void ossl_method_store_free(OSSL_METHOD_STORE *store);
  14. int ossl_method_store_init(OSSL_LIB_CTX *ctx);
  15. void ossl_method_store_cleanup(OSSL_LIB_CTX *ctx);
  16. int ossl_method_store_add(OSSL_METHOD_STORE *store, const OSSL_PROVIDER *prov,
  17. int nid, const char *properties, void *method,
  18. int (*method_up_ref)(void *),
  19. void (*method_destruct)(void *));
  20. int ossl_method_store_remove(OSSL_METHOD_STORE *store,
  21. int nid, const void *method);
  22. int ossl_method_store_fetch(OSSL_METHOD_STORE *store,
  23. int nid, const char *properties,
  24. void **method);
  25. int ossl_method_store_cache_get(OSSL_METHOD_STORE *store, int nid,
  26. const char *prop_query, void **method);
  27. int ossl_method_store_cache_set(OSSL_METHOD_STORE *store, int nid,
  28. const char *prop_query, void *method,
  29. int (*method_up_ref)(void *),
  30. void (*method_destruct)(void *));
  31. void ossl_method_store_flush_cache(OSSL_METHOD_STORE *store);
  32. =head1 DESCRIPTION
  33. OSSL_METHOD_STORE stores methods that can be queried using properties and a
  34. numeric identity (nid).
  35. Methods are expected to be library internal structures.
  36. It's left to the caller to define the exact contents.
  37. Numeric identities are expected to be an algorithm identity for the methods.
  38. It's left to the caller to define exactly what an algorithm is, and to allocate
  39. these numeric identities accordingly.
  40. The B<OSSL_METHOD_STORE> also holds an internal query cache, which is accessed
  41. separately (see L</Cache Functions> below).
  42. =head2 Store Functions
  43. ossl_method_store_init() initialises the method store subsystem in the scope of
  44. the library context I<ctx>.
  45. ossl_method_store_cleanup() cleans up and shuts down the implementation method
  46. store subsystem in the scope of the library context I<ctx>.
  47. ossl_method_store_new() create a new empty method store using the supplied
  48. I<ctx> to allow access to the required underlying property data.
  49. ossl_method_store_free() frees resources allocated to I<store>.
  50. ossl_method_store_add() adds the I<method> constructed from an implementation in
  51. the provider I<prov> to the I<store> as an instance of an algorithm indicated by
  52. I<nid> and the property definition I<properties>, unless the I<store> already
  53. has a method from the same provider with the same I<nid> and I<properties>.
  54. If the I<method_up_ref> function is given, it's called to increment the
  55. reference count of the method.
  56. If the I<method_destruct> function is given, it's called when this function
  57. fails to add the method to the store, or later on when it is being released from
  58. the I<store>.
  59. ossl_method_store_remove() removes the I<method> identified by I<nid> from the
  60. I<store>.
  61. ossl_method_store_fetch() queries I<store> for a method identified by I<nid>
  62. that matches the property query I<prop_query>.
  63. The result, if any, is returned in I<method>.
  64. ossl_method_store_flush_cache() flushes all cached entries associated with
  65. I<store>.
  66. =head2 Cache Functions
  67. ossl_method_store_cache_get() queries the cache associated with the I<store>
  68. for a method identified by I<nid> that matches the property query
  69. I<prop_query>.
  70. The result, if any, is returned in I<method>.
  71. ossl_method_store_cache_set() sets a cache entry identified by I<nid> with the
  72. property query I<prop_query> in the I<store>.
  73. Future calls to ossl_method_store_cache_get() will return the specified I<method>.
  74. The I<method_up_ref> function is called to increment the
  75. reference count of the method and the I<method_destruct> function is called
  76. to decrement it.
  77. =head1 RETURN VALUES
  78. ossl_method_store_new() returns a new method store object or NULL on failure.
  79. ossl_method_store_free(), ossl_method_store_add(),
  80. ossl_method_store_remove(), ossl_method_store_fetch(),
  81. ossl_method_store_cache_get(), ossl_method_store_cache_set() and
  82. ossl_method_store_flush_cache() return B<1> on success and B<0> on error.
  83. ossl_method_store_free() and ossl_method_store_cleanup() do not return any value.
  84. =head1 HISTORY
  85. This functionality was added to OpenSSL 3.0.
  86. =head1 COPYRIGHT
  87. Copyright 2019-2021 The OpenSSL Project Authors. All Rights Reserved.
  88. Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved.
  89. Licensed under the Apache License 2.0 (the "License"). You may not use this
  90. file except in compliance with the License. You can obtain a copy in the file
  91. LICENSE in the source distribution or at
  92. L<https://www.openssl.org/source/license.html>.
  93. =cut