Du kan inte välja fler än 25 ämnen Ämnen måste starta med en bokstav eller siffra, kan innehålla bindestreck ('-') och vara max 35 tecken långa.
 
 
 
 
 
 

94 rader
3.2 KiB

  1. /* Copyright (c) 2014, Google Inc.
  2. *
  3. * Permission to use, copy, modify, and/or distribute this software for any
  4. * purpose with or without fee is hereby granted, provided that the above
  5. * copyright notice and this permission notice appear in all copies.
  6. *
  7. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
  8. * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
  9. * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
  10. * SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
  11. * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
  12. * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
  13. * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */
  14. #ifndef OPENSSL_HEADER_TOOL_INTERNAL_H
  15. #define OPENSSL_HEADER_TOOL_INTERNAL_H
  16. #include <openssl/base.h>
  17. #include <string>
  18. #include <vector>
  19. OPENSSL_MSVC_PRAGMA(warning(push))
  20. // MSVC issues warning C4702 for unreachable code in its xtree header when
  21. // compiling with -D_HAS_EXCEPTIONS=0. See
  22. // https://connect.microsoft.com/VisualStudio/feedback/details/809962
  23. OPENSSL_MSVC_PRAGMA(warning(disable: 4702))
  24. #include <map>
  25. OPENSSL_MSVC_PRAGMA(warning(pop))
  26. #if defined(OPENSSL_WINDOWS)
  27. #define BORINGSSL_OPEN _open
  28. #define BORINGSSL_FDOPEN _fdopen
  29. #define BORINGSSL_CLOSE _close
  30. #define BORINGSSL_READ _read
  31. #define BORINGSSL_WRITE _write
  32. #else
  33. #define BORINGSSL_OPEN open
  34. #define BORINGSSL_FDOPEN fdopen
  35. #define BORINGSSL_CLOSE close
  36. #define BORINGSSL_READ read
  37. #define BORINGSSL_WRITE write
  38. #endif
  39. enum ArgumentType {
  40. kRequiredArgument,
  41. kOptionalArgument,
  42. kBooleanArgument,
  43. };
  44. struct argument {
  45. const char *name;
  46. ArgumentType type;
  47. const char *description;
  48. };
  49. bool ParseKeyValueArguments(std::map<std::string, std::string> *out_args, const
  50. std::vector<std::string> &args, const struct argument *templates);
  51. void PrintUsage(const struct argument *templates);
  52. bool GetUnsigned(unsigned *out, const std::string &arg_name,
  53. unsigned default_value,
  54. const std::map<std::string, std::string> &args);
  55. bool ReadAll(std::vector<uint8_t> *out, FILE *in);
  56. bool Ciphers(const std::vector<std::string> &args);
  57. bool Client(const std::vector<std::string> &args);
  58. bool DoPKCS12(const std::vector<std::string> &args);
  59. bool GenerateEd25519Key(const std::vector<std::string> &args);
  60. bool GenerateRSAKey(const std::vector<std::string> &args);
  61. bool MD5Sum(const std::vector<std::string> &args);
  62. bool Rand(const std::vector<std::string> &args);
  63. bool SHA1Sum(const std::vector<std::string> &args);
  64. bool SHA224Sum(const std::vector<std::string> &args);
  65. bool SHA256Sum(const std::vector<std::string> &args);
  66. bool SHA384Sum(const std::vector<std::string> &args);
  67. bool SHA512Sum(const std::vector<std::string> &args);
  68. bool Server(const std::vector<std::string> &args);
  69. bool Sign(const std::vector<std::string> &args);
  70. bool Speed(const std::vector<std::string> &args);
  71. // These values are DER encoded, RSA private keys.
  72. extern const uint8_t kDERRSAPrivate2048[];
  73. extern const size_t kDERRSAPrivate2048Len;
  74. extern const uint8_t kDERRSAPrivate4096[];
  75. extern const size_t kDERRSAPrivate4096Len;
  76. #endif /* !OPENSSL_HEADER_TOOL_INTERNAL_H */