[BACK]Return to hostfile.h CVS log [TXT][DIR] Up to [local] / src / usr.bin / ssh

Annotation of src/usr.bin/ssh/hostfile.h, Revision 1.24

1.24    ! djm         1: /* $OpenBSD: hostfile.h,v 1.23 2015/01/26 03:04:45 djm Exp $ */
1.6       niklas      2:
1.3       deraadt     3: /*
1.4       markus      4:  * Author: Tatu Ylonen <ylo@cs.hut.fi>
                      5:  * Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
                      6:  *                    All rights reserved
1.3       deraadt     7:  *
1.4       markus      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".
1.3       deraadt    13:  */
1.1       markus     14: #ifndef HOSTFILE_H
                     15: #define HOSTFILE_H
1.7       itojun     16:
1.1       markus     17: typedef enum {
1.18      djm        18:        HOST_OK, HOST_NEW, HOST_CHANGED, HOST_REVOKED, HOST_FOUND
1.1       markus     19: }       HostStatus;
1.5       markus     20:
1.19      djm        21: typedef enum {
                     22:        MRK_ERROR, MRK_NONE, MRK_REVOKE, MRK_CA
                     23: }      HostkeyMarker;
                     24:
                     25: struct hostkey_entry {
                     26:        char *host;
                     27:        char *file;
                     28:        u_long line;
1.21      djm        29:        struct sshkey *key;
1.19      djm        30:        HostkeyMarker marker;
                     31: };
                     32: struct hostkeys;
                     33:
                     34: struct hostkeys *init_hostkeys(void);
                     35: void    load_hostkeys(struct hostkeys *, const char *, const char *);
                     36: void    free_hostkeys(struct hostkeys *);
                     37:
1.21      djm        38: HostStatus check_key_in_hostkeys(struct hostkeys *, struct sshkey *,
1.19      djm        39:     const struct hostkey_entry **);
                     40: int     lookup_key_in_hostkeys_by_type(struct hostkeys *, int,
                     41:     const struct hostkey_entry **);
                     42:
1.21      djm        43: int     hostfile_read_key(char **, u_int *, struct sshkey *);
                     44: int     add_host_to_hostfile(const char *, const char *,
                     45:     const struct sshkey *, int);
1.23      djm        46:
1.24    ! djm        47: int     hostfile_replace_entries(const char *filename,
        !            48:     const char *host, const char *ip, struct sshkey **keys, size_t nkeys,
        !            49:     int store_hash, int quiet, int hash_alg);
1.15      djm        50:
                     51: #define HASH_MAGIC     "|1|"
                     52: #define HASH_DELIM     '|'
1.17      djm        53:
                     54: #define CA_MARKER      "@cert-authority"
1.18      djm        55: #define REVOKE_MARKER  "@revoked"
1.15      djm        56:
                     57: char   *host_hash(const char *, const char *, u_int);
1.22      djm        58:
                     59: /*
                     60:  * Iterate through a hostkeys file, optionally parsing keys and matching
                     61:  * hostnames. Allows access to the raw keyfile lines to allow
                     62:  * streaming edits to the file to take place.
                     63:  */
1.24    ! djm        64: #define HKF_WANT_MATCH         (1)     /* return only matching hosts/addrs */
1.22      djm        65: #define HKF_WANT_PARSE_KEY     (1<<1)  /* need key parsed */
                     66:
1.24    ! djm        67: #define HKF_STATUS_OK          0       /* Line parsed, didn't match host */
        !            68: #define HKF_STATUS_INVALID     1       /* line had parse error */
        !            69: #define HKF_STATUS_COMMENT     2       /* valid line contained no key */
        !            70: #define HKF_STATUS_MATCHED     3       /* hostname or IP matched */
        !            71:
        !            72: #define HKF_MATCH_HOST         (1)     /* hostname matched */
        !            73: #define HKF_MATCH_IP           (1<<1)  /* address matched */
        !            74: #define HKF_MATCH_HOST_HASHED  (1<<2)  /* hostname was hashed */
        !            75: #define HKF_MATCH_IP_HASHED    (1<<3)  /* address was hashed */
        !            76: /* XXX HKF_MATCH_KEY_TYPE? */
1.22      djm        77:
                     78: /*
                     79:  * The callback function receives this as an argument for each matching
                     80:  * hostkey line. The callback may "steal" the 'key' field by setting it to NULL.
                     81:  * If a parse error occurred, then "hosts" and subsequent options may be NULL.
                     82:  */
                     83: struct hostkey_foreach_line {
                     84:        const char *path; /* Path of file */
                     85:        u_long linenum; /* Line number */
1.24    ! djm        86:        u_int status;   /* One of HKF_STATUS_* */
        !            87:        u_int match;    /* Zero or more of HKF_MATCH_* OR'd together */
1.22      djm        88:        char *line;     /* Entire key line; mutable by callback */
                     89:        int marker;     /* CA/revocation markers; indicated by MRK_* value */
                     90:        const char *hosts; /* Raw hosts text, may be hashed or list multiple */
                     91:        const char *rawkey; /* Text of key and any comment following it */
1.24    ! djm        92:        int keytype;    /* Type of key; KEY_UNSPEC for invalid/comment lines */
1.22      djm        93:        struct sshkey *key; /* Key, if parsed ok and HKF_WANT_MATCH_HOST set */
                     94:        const char *comment; /* Any comment following the key */
                     95: };
                     96:
                     97: /*
                     98:  * Callback fires for each line (or matching line if a HKF_WANT_* option
                     99:  * is set). The foreach loop will terminate if the callback returns a non-
                    100:  * zero exit status.
                    101:  */
                    102: typedef int hostkeys_foreach_fn(struct hostkey_foreach_line *l, void *ctx);
                    103:
1.24    ! djm       104: /* Iterate over a hostkeys file */
1.22      djm       105: int hostkeys_foreach(const char *path, hostkeys_foreach_fn *callback, void *ctx,
1.24    ! djm       106:     const char *host, const char *ip, u_int options);
1.1       markus    107:
                    108: #endif