31 extern int use_privsep;
32 #define PRIVSEP(x) (use_privsep ? mm_##x : x) 34 enum mm_keytype {MM_NOKEY, MM_HOSTKEY, MM_USERKEY, MM_RSAHOSTKEY, MM_RSAUSERKEY};
40 void mm_log_handler(LogLevel,
const char *,
void *);
41 int mm_is_monitor(
void);
42 DH *mm_choose_dh(
int,
int,
int);
43 int mm_key_sign(Key *, u_char **, u_int *,
const u_char *, u_int,
const char *);
44 void mm_inform_authserv(
char *,
char *);
45 struct passwd *mm_getpwnamallow(
const char *);
46 char *mm_auth2_read_banner(
void);
47 int mm_auth_password(
struct Authctxt *,
char *);
48 int mm_key_allowed(
enum mm_keytype,
const char *,
const char *, Key *,
int);
49 int mm_user_key_allowed(
struct passwd *, Key *,
int);
50 int mm_hostbased_key_allowed(
struct passwd *,
const char *,
52 int mm_auth_rhosts_rsa_key_allowed(
struct passwd *,
const char *,
54 int mm_key_verify(Key *, u_char *, u_int, u_char *, u_int);
55 int mm_auth_rsa_key_allowed(
struct passwd *, BIGNUM *, Key **);
56 int mm_auth_rsa_verify_response(Key *, BIGNUM *, u_char *);
57 BIGNUM *mm_auth_rsa_generate_challenge(Key *);
60 OM_uint32 mm_ssh_gssapi_server_ctx(Gssctxt **, gss_OID);
61 OM_uint32 mm_ssh_gssapi_accept_ctx(Gssctxt *,
62 gss_buffer_desc *, gss_buffer_desc *, OM_uint32 *);
63 int mm_ssh_gssapi_userok(
char *user,
struct passwd *,
int gssapi_keyex);
64 OM_uint32 mm_ssh_gssapi_checkmic(Gssctxt *, gss_buffer_t, gss_buffer_t);
65 OM_uint32 mm_ssh_gssapi_sign(Gssctxt *, gss_buffer_t, gss_buffer_t);
66 int mm_ssh_gssapi_localname(
char **user);
67 OM_uint32 mm_gss_indicate_mechs(OM_uint32 *minor_status,
68 gss_OID_set *mech_set);
69 char *mm_ssh_gssapi_last_error(Gssctxt *ctxt, OM_uint32 *maj, OM_uint32 *min);
70 int mm_ssh_gssapi_update_creds(ssh_gssapi_ccache *);
74 void mm_start_pam(
struct Authctxt *);
75 u_int mm_do_pam_account(
void);
76 void *mm_sshpam_init_ctx(
struct Authctxt *);
77 int mm_sshpam_query(
void *,
char **,
char **, u_int *,
char ***, u_int **);
78 int mm_sshpam_respond(
void *, u_int,
char **);
79 void mm_sshpam_free_ctx(
void *);
82 #ifdef SSH_AUDIT_EVENTS 84 void mm_audit_event(ssh_audit_event_t);
85 void mm_audit_run_command(
const char *);
89 void mm_terminate(
void);
90 int mm_pty_allocate(
int *,
int *,
char *,
size_t);
91 void mm_session_pty_cleanup2(
struct Session *);
94 void mm_ssh1_session_id(u_char *);
95 int mm_ssh1_session_key(BIGNUM *);
98 struct newkeys *mm_newkeys_from_blob(u_char *,
int);
99 int mm_newkeys_to_blob(
int, u_char **, u_int *);
101 void monitor_apply_keystate(
struct monitor *);
102 void mm_get_keystate(
struct monitor *);
103 void mm_send_keystate(
struct monitor*);
106 int mm_bsdauth_query(
void *,
char **,
char **, u_int *,
char ***, u_int **);
107 int mm_bsdauth_respond(
void *, u_int,
char **);
110 int mm_skey_query(
void *,
char **,
char **, u_int *,
char ***, u_int **);
111 int mm_skey_respond(
void *, u_int,
char **);
114 void mm_init_compression(
struct mm_master *);