Add blacklist feature for weak Debian-generated ssh keys.
[dragonfly.git] / crypto / openssh-5 / misc.h
1 /* $OpenBSD: misc.h,v 1.37 2007/12/27 14:22:08 dtucker Exp $ */
2
3 /*
4  * Author: Tatu Ylonen <ylo@cs.hut.fi>
5  * Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
6  *                    All rights reserved
7  *
8  * As far as I am concerned, the code I have written for this software
9  * can be used freely for any purpose.  Any derived versions of this
10  * software must be clearly marked as such, and if the derived work is
11  * incompatible with the protocol description in the RFC file, it must be
12  * called by a name other than "ssh" or "Secure Shell".
13  */
14
15 #ifndef _MISC_H
16 #define _MISC_H
17
18 /* misc.c */
19
20 char    *chop(char *);
21 char    *strdelim(char **);
22 int      set_nonblock(int);
23 int      unset_nonblock(int);
24 void     set_nodelay(int);
25 int      a2port(const char *);
26 int      a2tun(const char *, int *);
27 char    *put_host_port(const char *, u_short);
28 char    *hpdelim(char **);
29 char    *cleanhostname(char *);
30 char    *colon(char *);
31 long     convtime(const char *);
32 char    *tilde_expand_filename(const char *, uid_t);
33 char    *percent_expand(const char *, ...) __attribute__((__sentinel__));
34 char    *tohex(const void *, size_t);
35 void     sanitise_stdfd(void);
36
37 struct passwd *pwcopy(struct passwd *);
38 const char *ssh_gai_strerror(int);
39
40 typedef struct arglist arglist;
41 struct arglist {
42         char    **list;
43         u_int   num;
44         u_int   nalloc;
45 };
46 void     addargs(arglist *, char *, ...)
47              __attribute__((format(printf, 2, 3)));
48 void     replacearg(arglist *, u_int, char *, ...)
49              __attribute__((format(printf, 3, 4)));
50 void     freeargs(arglist *);
51
52 int      tun_open(int, int);
53
54 /* Common definitions for ssh tunnel device forwarding */
55 #define SSH_TUNMODE_NO          0x00
56 #define SSH_TUNMODE_POINTOPOINT 0x01
57 #define SSH_TUNMODE_ETHERNET    0x02
58 #define SSH_TUNMODE_DEFAULT     SSH_TUNMODE_POINTOPOINT
59 #define SSH_TUNMODE_YES         (SSH_TUNMODE_POINTOPOINT|SSH_TUNMODE_ETHERNET)
60
61 #define SSH_TUNID_ANY           0x7fffffff
62 #define SSH_TUNID_ERR           (SSH_TUNID_ANY - 1)
63 #define SSH_TUNID_MAX           (SSH_TUNID_ANY - 2)
64
65 /* Functions to extract or store big-endian words of various sizes */
66 u_int64_t       get_u64(const void *)
67     __attribute__((__bounded__( __minbytes__, 1, 8)));
68 u_int32_t       get_u32(const void *)
69     __attribute__((__bounded__( __minbytes__, 1, 4)));
70 u_int16_t       get_u16(const void *)
71     __attribute__((__bounded__( __minbytes__, 1, 2)));
72 void            put_u64(void *, u_int64_t)
73     __attribute__((__bounded__( __minbytes__, 1, 8)));
74 void            put_u32(void *, u_int32_t)
75     __attribute__((__bounded__( __minbytes__, 1, 4)));
76 void            put_u16(void *, u_int16_t)
77     __attribute__((__bounded__( __minbytes__, 1, 2)));
78
79
80 /* readpass.c */
81
82 #define RP_ECHO                 0x0001
83 #define RP_ALLOW_STDIN          0x0002
84 #define RP_ALLOW_EOF            0x0004
85 #define RP_USE_ASKPASS          0x0008
86
87 char    *read_passphrase(const char *, int);
88 int      ask_permission(const char *, ...) __attribute__((format(printf, 1, 2)));
89 int      read_keyfile_line(FILE *, const char *, char *, size_t, u_long *);
90
91 #endif /* _MISC_H */