]> andersk Git - openssh.git/blobdiff - sshconnect.h
- (djm) [README README.privsep] Mention FreeBSD and NetBSD as being
[openssh.git] / sshconnect.h
index c15ed4bc4f8d69f90af25a71dd3bf17123792b42..0be30fe695aa838ddded6f826798c9a4f50455e6 100644 (file)
@@ -1,4 +1,4 @@
-/*     $OpenBSD: sshconnect.h,v 1.11 2001/06/26 06:33:03 itojun Exp $  */
+/*     $OpenBSD: sshconnect.h,v 1.17 2002/06/19 00:27:55 deraadt Exp $ */
 
 /*
  * Copyright (c) 2000 Markus Friedl.  All rights reserved.
 #ifndef SSHCONNECT_H
 #define SSHCONNECT_H
 
+typedef struct Sensitive Sensitive;
+struct Sensitive {
+       Key     **keys;
+       int     nkeys;
+       int     external_keysign;
+};
+
 int
-ssh_connect(const char *, struct sockaddr_storage *, u_short, int,
-    int, struct passwd *, const char *);
+ssh_connect(const char *, struct sockaddr_storage *, u_short, int, int,
+    int, const char *);
 
 void
-ssh_login(Key **, int, const char *, struct sockaddr *, struct passwd *);
+ssh_login(Sensitive *, const char *, struct sockaddr *, struct passwd *);
+
+int     verify_host_key(char *, struct sockaddr *, Key *);
+
+void    ssh_kex(char *, struct sockaddr *);
+void    ssh_kex2(char *, struct sockaddr *);
 
-int    verify_host_key(char *, struct sockaddr *, Key *);
+void    ssh_userauth1(const char *, const char *, char *, Sensitive *);
+void    ssh_userauth2(const char *, const char *, char *, Sensitive *);
 
-void   ssh_kex(char *, struct sockaddr *);
-void   ssh_kex2(char *, struct sockaddr *);
+void    ssh_put_password(char *);
 
-void   ssh_userauth1(const char *, const char *, char *, Key **, int);
-void   ssh_userauth2(const char *, const char *, char *, Key **, int);
 
-void   ssh_put_password(char *);
+/*
+ * Macros to raise/lower permissions.
+ */
+#define PRIV_START do {                                \
+       int save_errno = errno;                 \
+       (void)seteuid(original_effective_uid);  \
+       errno = save_errno;                     \
+} while (0)
+
+#define PRIV_END do {                          \
+       int save_errno = errno;                 \
+       (void)seteuid(original_real_uid);       \
+       errno = save_errno;                     \
+} while (0)
 
 #endif
This page took 0.037422 seconds and 4 git commands to generate.