rpcsec_tls.h 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. /*-
  2. * SPDX-License-Identifier: BSD-2-Clause-FreeBSD
  3. *
  4. * Copyright (c) 2020 Rick Macklem
  5. *
  6. * Redistribution and use in source and binary forms, with or without
  7. * modification, are permitted provided that the following conditions
  8. * are met:
  9. * 1. Redistributions of source code must retain the above copyright
  10. * notice, this list of conditions and the following disclaimer.
  11. * 2. Redistributions in binary form must reproduce the above copyright
  12. * notice, this list of conditions and the following disclaimer in the
  13. * documentation and/or other materials provided with the distribution.
  14. *
  15. * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
  16. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  17. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  18. * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
  19. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  20. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  21. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  22. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  23. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  24. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  25. * SUCH DAMAGE.
  26. *
  27. * $FreeBSD$
  28. */
  29. #ifndef _RPC_RPCSEC_TLS_H_
  30. #define _RPC_RPCSEC_TLS_H_
  31. /* Operation values for rpctls syscall. */
  32. #define RPCTLS_SYSC_CLSETPATH 1
  33. #define RPCTLS_SYSC_CLSOCKET 2
  34. #define RPCTLS_SYSC_CLSHUTDOWN 3
  35. #define RPCTLS_SYSC_SRVSETPATH 4
  36. #define RPCTLS_SYSC_SRVSOCKET 5
  37. #define RPCTLS_SYSC_SRVSHUTDOWN 6
  38. /* System call used by the rpctlscd, rpctlssd daemons. */
  39. int rpctls_syscall(int, const char *);
  40. /* Flag bits to indicate certificate results. */
  41. #define RPCTLS_FLAGS_HANDSHAKE 0x01
  42. #define RPCTLS_FLAGS_GOTCERT 0x02
  43. #define RPCTLS_FLAGS_SELFSIGNED 0x04
  44. #define RPCTLS_FLAGS_VERIFIED 0x08
  45. #define RPCTLS_FLAGS_DISABLED 0x10
  46. #define RPCTLS_FLAGS_CERTUSER 0x20
  47. #define RPCTLS_FLAGS_HANDSHFAIL 0x40
  48. /* Error return values for upcall rpcs. */
  49. #define RPCTLSERR_OK 0
  50. #define RPCTLSERR_NOCLOSE 1
  51. #define RPCTLSERR_NOSSL 2
  52. #define RPCTLSERR_NOSOCKET 3
  53. #ifdef _KERNEL
  54. /* Functions that perform upcalls to the rpctlsd daemon. */
  55. enum clnt_stat rpctls_connect(CLIENT *newclient, char *certname,
  56. struct socket *so, uint64_t *sslp, uint32_t *reterr);
  57. enum clnt_stat rpctls_cl_handlerecord(uint64_t sec, uint64_t usec,
  58. uint64_t ssl, uint32_t *reterr);
  59. enum clnt_stat rpctls_srv_handlerecord(uint64_t sec, uint64_t usec,
  60. uint64_t ssl, uint32_t *reterr);
  61. enum clnt_stat rpctls_cl_disconnect(uint64_t sec, uint64_t usec,
  62. uint64_t ssl, uint32_t *reterr);
  63. enum clnt_stat rpctls_srv_disconnect(uint64_t sec, uint64_t usec,
  64. uint64_t ssl, uint32_t *reterr);
  65. /* Initialization function for rpcsec_tls. */
  66. int rpctls_init(void);
  67. /* Get TLS information function. */
  68. bool rpctls_getinfo(u_int *maxlen, bool rpctlscd_run,
  69. bool rpctlssd_run);
  70. /* String for AUTH_TLS reply verifier. */
  71. #define RPCTLS_START_STRING "STARTTLS"
  72. /* ssl refno value to indicate TLS handshake being done. */
  73. #define RPCTLS_REFNO_HANDSHAKE 0xFFFFFFFFFFFFFFFFULL
  74. #endif /* _KERNEL */
  75. #endif /* _RPC_RPCSEC_TLS_H_ */