cert-fingerprint 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. #!/bin/sh
  2. #
  3. # Copyright (C) 2016 Red Hat, Inc.
  4. #
  5. # This file is part of openconnect.
  6. #
  7. # This is free software; you can redistribute it and/or
  8. # modify it under the terms of the GNU Lesser General Public License
  9. # as published by the Free Software Foundation; either version 2.1 of
  10. # the License, or (at your option) any later version.
  11. #
  12. # This library is distributed in the hope that it will be useful, but
  13. # WITHOUT ANY WARRANTY; without even the implied warranty of
  14. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  15. # Lesser General Public License for more details.
  16. #
  17. # You should have received a copy of the GNU Lesser General Public License
  18. # along with this program. If not, see <http://www.gnu.org/licenses/>
  19. # This test uses LD_PRELOAD
  20. PRELOAD=1
  21. SERV="${SERV:-../src/ocserv}"
  22. srcdir=${srcdir:-.}
  23. top_builddir=${top_builddir:-..}
  24. . `dirname $0`/common.sh
  25. echo "Testing certificate auth..."
  26. launch_simple_sr_server -d 1 -f -c configs/test-user-pass.config
  27. PID=$!
  28. wait_server $PID
  29. expect_cert_fail() {
  30. SERVERCERT=$1
  31. echo -n "Testing with cert fingerprint $SERVERCERT..."
  32. ( echo "test" | LD_PRELOAD=libsocket_wrapper.so $OPENCONNECT -q $ADDRESS:443 -u test --servercert $SERVERCERT --cookieonly >/dev/null 2>&1) &&
  33. fail $PID "Accepted wrong fingerprint $SERVERCERT"
  34. echo "ok (rejected)"
  35. }
  36. expect_cert_success() {
  37. SERVERCERT=$1
  38. echo -n "Testing with cert fingerprint $SERVERCERT..."
  39. ( echo "test" | LD_PRELOAD=libsocket_wrapper.so $OPENCONNECT -q $ADDRESS:443 -u test --servercert $SERVERCERT --cookieonly >/dev/null 2>&1) ||
  40. fail $PID "Rejected good fingerprint $SERVERCERT"
  41. echo "ok (accepted)"
  42. }
  43. expect_cert_success d66b507ae074d03b02eafca40d35f87dd81049d3
  44. expect_cert_success D66B507AE074D03B02EAFCA40D35F87DD81049D3
  45. expect_cert_fail d66b507ae074d03b02eafca40d35f87dd81049d34
  46. expect_cert_fail D66B507AE074D03B02EAFCA40D35F87DD81049D34
  47. expect_cert_fail d66b507ae074d03b02eafca41d35f87dd81049d3
  48. expect_cert_fail D66B507AE074D03B02EAFCA41D35F87DD81049D3
  49. expect_cert_success d66b507ae074d03b0
  50. expect_cert_success D66B507AE074D03B0
  51. expect_cert_fail d66
  52. expect_cert_fail D66
  53. expect_cert_success d66B
  54. expect_cert_success D66b
  55. expect_cert_success sha1:a82547f68f44d6351bef6cacd1d7b96e84f9dfa3
  56. expect_cert_success sha1:A82547F68F44D6351BEF6CACD1D7B96E84F9DFA3
  57. expect_cert_fail sha1:a82547f68f44d6351bef6cacd1d7b96e84f9dfa34
  58. expect_cert_fail sha1:A82547F68F44D6351BEF6CACD1D7B96E84F9DFA34
  59. expect_cert_fail sha1:a82547f68f44d6352bef6cacd1d7b96e84f9dfa3
  60. expect_cert_fail sha1:A82547F68F44D6352BEF6CACD1D7B96E84F9DFA3
  61. expect_cert_success sha1:a82547f68f44d635
  62. expect_cert_success sha1:A82547F68F44D635
  63. expect_cert_fail sha1:a82
  64. expect_cert_fail sha1:A82
  65. expect_cert_success sha1:a825
  66. expect_cert_success sha1:A825
  67. expect_cert_success sha256:c69dec71fcf2deb390b2ff4d70ebdeffc61556ffa91ebe2a3425c45eb365e6cf
  68. expect_cert_success sha256:C69DEC71FCF2DEB390B2FF4D70EBDEFFC61556FFA91EBE2A3425C45EB365E6CF
  69. expect_cert_fail sha256:c69dec71fcf2deb390b2ff4d70ebdeffc61556ffa91ebe2a3425c45eb365e6cf3
  70. expect_cert_fail sha256:C69DEC71FCF2DEB390B2FF4D70EBDEFFC61556FFA91EBE2A3425C45EB365E6CF3
  71. expect_cert_fail sha256:c69dec71fcf2deb390b2fe4d70ebdeffc61556ffa91ebe2a3425c45eb365e6cf
  72. expect_cert_fail sha256:C69DEC71FCF2DEB390B2FE4D70EBDEFFC61556FFA91EBE2A3425C45EB365E6CF
  73. expect_cert_success sha256:c69dec71fcf2deb390b2f
  74. expect_cert_success sha256:C69DEC71FCF2DEB390B2F
  75. expect_cert_fail sha256:c69
  76. expect_cert_fail sha256:C69
  77. expect_cert_success sha256:c69D
  78. expect_cert_success sha256:C69d
  79. # pin-sha256: is case sensitive.
  80. expect_cert_success pin-sha256:xp3scfzy3rOQsv9NcOve/8YVVv+pHr4qNCXEXrNl5s8=
  81. expect_cert_fail pin-sha256:xp3scfzy3rOQsv9NcOvE/8YVVv+pHr4qNCXEXrNl5s8=
  82. expect_cert_fail pin-sha256:XP3SCFZY3ROQSV9NCOVE/8YVVV+PHR4QNCXEXRNL5S8=
  83. expect_cert_success pin-sha256:xp3scfzy3rOQsv9NcO
  84. expect_cert_fail pin-sha256:xp3scfzy3rOQsv9NCO
  85. expect_cert_fail pin-sha256:xp3
  86. expect_cert_fail pin-sha256:xp3
  87. expect_cert_success pin-sha256:xp3s
  88. expect_cert_fail pin-sha256:xP3s
  89. cleanup
  90. exit 0