auth_gssapi.h 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. /* include/gssrpc/auth_gssapi.h - GSS-API style auth parameters for RPC */
  2. /*
  3. * Copyright 1993 OpenVision Technologies, Inc., All Rights Reserved.
  4. */
  5. #ifndef GSSRPC_AUTH_GSSAPI_H
  6. #define GSSRPC_AUTH_GSSAPI_H
  7. GSSRPC__BEGIN_DECLS
  8. #define AUTH_GSSAPI_EXIT 0
  9. #define AUTH_GSSAPI_INIT 1
  10. #define AUTH_GSSAPI_CONTINUE_INIT 2
  11. #define AUTH_GSSAPI_MSG 3
  12. #define AUTH_GSSAPI_DESTROY 4
  13. /*
  14. * Yuck. Some sys/types.h files leak symbols
  15. */
  16. #ifdef major
  17. #undef major
  18. #endif
  19. #ifdef minor
  20. #undef minor
  21. #endif
  22. typedef struct _auth_gssapi_name {
  23. char *name;
  24. gss_OID type;
  25. } auth_gssapi_name;
  26. typedef struct _auth_gssapi_creds {
  27. uint32_t version;
  28. bool_t auth_msg;
  29. gss_buffer_desc client_handle;
  30. } auth_gssapi_creds;
  31. typedef struct _auth_gssapi_init_arg {
  32. uint32_t version;
  33. gss_buffer_desc token;
  34. } auth_gssapi_init_arg;
  35. typedef struct _auth_gssapi_init_res {
  36. uint32_t version;
  37. gss_buffer_desc client_handle;
  38. OM_uint32 gss_major, gss_minor;
  39. gss_buffer_desc token;
  40. gss_buffer_desc signed_isn;
  41. } auth_gssapi_init_res;
  42. typedef void (*auth_gssapi_log_badauth_func)
  43. (OM_uint32 major,
  44. OM_uint32 minor,
  45. struct sockaddr_in *raddr,
  46. caddr_t data);
  47. typedef void (*auth_gssapi_log_badverf_func)
  48. (gss_name_t client,
  49. gss_name_t server,
  50. struct svc_req *rqst,
  51. struct rpc_msg *msg,
  52. caddr_t data);
  53. typedef void (*auth_gssapi_log_miscerr_func)
  54. (struct svc_req *rqst,
  55. struct rpc_msg *msg,
  56. char *error,
  57. caddr_t data);
  58. bool_t xdr_gss_buf(XDR *, gss_buffer_t);
  59. bool_t xdr_authgssapi_creds(XDR *, auth_gssapi_creds *);
  60. bool_t xdr_authgssapi_init_arg(XDR *, auth_gssapi_init_arg *);
  61. bool_t xdr_authgssapi_init_res(XDR *, auth_gssapi_init_res *);
  62. bool_t auth_gssapi_wrap_data
  63. (OM_uint32 *major, OM_uint32 *minor,
  64. gss_ctx_id_t context, uint32_t seq_num, XDR
  65. *out_xdrs, bool_t (*xdr_func)(), caddr_t
  66. xdr_ptr);
  67. bool_t auth_gssapi_unwrap_data
  68. (OM_uint32 *major, OM_uint32 *minor,
  69. gss_ctx_id_t context, uint32_t seq_num, XDR
  70. *in_xdrs, bool_t (*xdr_func)(), caddr_t
  71. xdr_ptr);
  72. AUTH *auth_gssapi_create
  73. (CLIENT *clnt,
  74. OM_uint32 *major_status,
  75. OM_uint32 *minor_status,
  76. gss_cred_id_t claimant_cred_handle,
  77. gss_name_t target_name,
  78. gss_OID mech_type,
  79. OM_uint32 req_flags,
  80. OM_uint32 time_req,
  81. gss_OID *actual_mech_type,
  82. OM_uint32 *ret_flags,
  83. OM_uint32 *time_rec);
  84. AUTH *auth_gssapi_create_default
  85. (CLIENT *clnt, char *service_name);
  86. void auth_gssapi_display_status
  87. (char *msg, OM_uint32 major,
  88. OM_uint32 minor);
  89. bool_t auth_gssapi_seal_seq
  90. (gss_ctx_id_t context, uint32_t seq_num, gss_buffer_t out_buf);
  91. bool_t auth_gssapi_unseal_seq
  92. (gss_ctx_id_t context, gss_buffer_t in_buf, uint32_t *seq_num);
  93. bool_t svcauth_gssapi_set_names
  94. (auth_gssapi_name *names, int num);
  95. void svcauth_gssapi_unset_names
  96. (void);
  97. void svcauth_gssapi_set_log_badauth_func
  98. (auth_gssapi_log_badauth_func func,
  99. caddr_t data);
  100. void svcauth_gssapi_set_log_badverf_func
  101. (auth_gssapi_log_badverf_func func,
  102. caddr_t data);
  103. void svcauth_gssapi_set_log_miscerr_func
  104. (auth_gssapi_log_miscerr_func func,
  105. caddr_t data);
  106. void svcauth_gss_set_log_badauth_func(auth_gssapi_log_badauth_func,
  107. caddr_t);
  108. void svcauth_gss_set_log_badverf_func(auth_gssapi_log_badverf_func,
  109. caddr_t);
  110. void svcauth_gss_set_log_miscerr_func(auth_gssapi_log_miscerr_func,
  111. caddr_t data);
  112. #define GSS_COPY_BUFFER(dest, src) { \
  113. (dest).length = (src).length; \
  114. (dest).value = (src).value; }
  115. #define GSS_DUP_BUFFER(dest, src) { \
  116. (dest).length = (src).length; \
  117. (dest).value = (void *) malloc((dest).length); \
  118. memcpy((dest).value, (src).value, (dest).length); }
  119. #define GSS_BUFFERS_EQUAL(b1, b2) (((b1).length == (b2).length) && \
  120. !memcmp((b1).value,(b2).value,(b1.length)))
  121. GSSRPC__END_DECLS
  122. #endif /* !defined(GSSRPC_AUTH_GSSAPI_H) */