SSLUtil.java 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. /*
  2. * Copyright (c) 2007, Cameron Rich
  3. *
  4. * All rights reserved.
  5. *
  6. * Redistribution and use in source and binary forms, with or without
  7. * modification, are permitted provided that the following conditions are met:
  8. *
  9. * * Redistributions of source code must retain the above copyright notice,
  10. * this list of conditions and the following disclaimer.
  11. * * Redistributions in binary form must reproduce the above copyright notice,
  12. * this list of conditions and the following disclaimer in the documentation
  13. * and/or other materials provided with the distribution.
  14. * * Neither the name of the axTLS project nor the names of its contributors
  15. * may be used to endorse or promote products derived from this software
  16. * without specific prior written permission.
  17. *
  18. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  19. * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  20. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  21. * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
  22. * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
  23. * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
  24. * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
  25. * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
  26. * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
  27. * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
  28. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  29. */
  30. /*
  31. * A wrapper around the unmanaged interface to give a semi-decent Java API
  32. */
  33. package axTLSj;
  34. import java.io.*;
  35. import java.util.*;
  36. /**
  37. * @class SSLUtil
  38. * @ingroup java_api
  39. * @brief Some global helper functions.
  40. *
  41. */
  42. public class SSLUtil
  43. {
  44. /**
  45. * @brief Load up the ddl/shared library
  46. */
  47. static
  48. {
  49. System.loadLibrary("axtlsj");
  50. }
  51. /**
  52. * @brief Return the build mode of the axTLS project.
  53. * @return The build mode is one of:
  54. * - SSL_BUILD_SERVER_ONLY
  55. * - SSL_BUILD_ENABLE_VERIFICATION
  56. * - SSL_BUILD_ENABLE_CLIENT
  57. * - SSL_BUILD_FULL_MODE
  58. */
  59. public static int buildMode()
  60. {
  61. return axtlsj.ssl_get_config(axtlsj.SSL_BUILD_MODE);
  62. }
  63. /**
  64. * @brief Return the number of chained certificates that the client/server
  65. * supports.
  66. * @return The number of supported client/server certificates.
  67. */
  68. public static int maxCerts()
  69. {
  70. return axtlsj.ssl_get_config(axtlsj.SSL_MAX_CERT_CFG_OFFSET);
  71. }
  72. /**
  73. * @brief Return the number of CA certificates that the client/server
  74. * supports.
  75. * @return The number of supported CA certificates.
  76. */
  77. public static int maxCACerts()
  78. {
  79. return axtlsj.ssl_get_config(axtlsj.SSL_MAX_CA_CERT_CFG_OFFSET);
  80. }
  81. /**
  82. * @brief Indicate if PEM is supported.
  83. * @return true if PEM supported.
  84. */
  85. public static boolean hasPEM()
  86. {
  87. return axtlsj.ssl_get_config(axtlsj.SSL_HAS_PEM) > 0 ? true : false;
  88. }
  89. /**
  90. * @brief Display the text string of the error.
  91. * @param error_code [in] The integer error code.
  92. * @see ssl.h for the error code list.
  93. */
  94. public static void displayError(int error_code)
  95. {
  96. axtlsj.ssl_display_error(error_code);
  97. }
  98. /**
  99. * @brief Return the version of the axTLS project.
  100. */
  101. public static String version()
  102. {
  103. return axtlsj.ssl_version();
  104. }
  105. }