xref: /freebsd/crypto/openssh/misc.h (revision 043840df5be0cf8490b48a08fe6d9c316f473f58)
1043840dfSDag-Erling Smørgrav /*	$OpenBSD: misc.h,v 1.25 2005/07/14 04:00:43 dtucker Exp $	*/
21e8db6e2SBrian Feldman 
31e8db6e2SBrian Feldman /*
41e8db6e2SBrian Feldman  * Author: Tatu Ylonen <ylo@cs.hut.fi>
51e8db6e2SBrian Feldman  * Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
61e8db6e2SBrian Feldman  *                    All rights reserved
71e8db6e2SBrian Feldman  *
81e8db6e2SBrian Feldman  * As far as I am concerned, the code I have written for this software
91e8db6e2SBrian Feldman  * can be used freely for any purpose.  Any derived versions of this
101e8db6e2SBrian Feldman  * software must be clearly marked as such, and if the derived work is
111e8db6e2SBrian Feldman  * incompatible with the protocol description in the RFC file, it must be
121e8db6e2SBrian Feldman  * called by a name other than "ssh" or "Secure Shell".
131e8db6e2SBrian Feldman  */
141e8db6e2SBrian Feldman 
15d74d50a8SDag-Erling Smørgrav /* misc.c */
16d74d50a8SDag-Erling Smørgrav 
17ae1f160dSDag-Erling Smørgrav char	*chop(char *);
18ae1f160dSDag-Erling Smørgrav char	*strdelim(char **);
19d74d50a8SDag-Erling Smørgrav int	 set_nonblock(int);
20d74d50a8SDag-Erling Smørgrav int	 unset_nonblock(int);
21ae1f160dSDag-Erling Smørgrav void	 set_nodelay(int);
22ae1f160dSDag-Erling Smørgrav int	 a2port(const char *);
235e8dbd04SDag-Erling Smørgrav char	*hpdelim(char **);
24ae1f160dSDag-Erling Smørgrav char	*cleanhostname(char *);
25ae1f160dSDag-Erling Smørgrav char	*colon(char *);
26ae1f160dSDag-Erling Smørgrav long	 convtime(const char *);
27043840dfSDag-Erling Smørgrav char	*tilde_expand_filename(const char *, uid_t);
28043840dfSDag-Erling Smørgrav char	*percent_expand(const char *, ...) __attribute__((__sentinel__));
29043840dfSDag-Erling Smørgrav char	*tohex(const u_char *, u_int);
301e8db6e2SBrian Feldman 
31ae1f160dSDag-Erling Smørgrav struct passwd *pwcopy(struct passwd *);
321e8db6e2SBrian Feldman 
33ae1f160dSDag-Erling Smørgrav typedef struct arglist arglist;
34ae1f160dSDag-Erling Smørgrav struct arglist {
35ae1f160dSDag-Erling Smørgrav 	char    **list;
36d74d50a8SDag-Erling Smørgrav 	u_int   num;
37d74d50a8SDag-Erling Smørgrav 	u_int   nalloc;
38ae1f160dSDag-Erling Smørgrav };
39ae1f160dSDag-Erling Smørgrav void	 addargs(arglist *, char *, ...) __attribute__((format(printf, 2, 3)));
40d74d50a8SDag-Erling Smørgrav 
41d74d50a8SDag-Erling Smørgrav /* readpass.c */
42d74d50a8SDag-Erling Smørgrav 
43d74d50a8SDag-Erling Smørgrav #define RP_ECHO			0x0001
44d74d50a8SDag-Erling Smørgrav #define RP_ALLOW_STDIN		0x0002
45d74d50a8SDag-Erling Smørgrav #define RP_ALLOW_EOF		0x0004
46d74d50a8SDag-Erling Smørgrav #define RP_USE_ASKPASS		0x0008
47d74d50a8SDag-Erling Smørgrav 
48d74d50a8SDag-Erling Smørgrav char	*read_passphrase(const char *, int);
495e8dbd04SDag-Erling Smørgrav int	 ask_permission(const char *, ...) __attribute__((format(printf, 1, 2)));
505e8dbd04SDag-Erling Smørgrav int	 read_keyfile_line(FILE *, const char *, char *, size_t, u_long *);
51