2 * Copyright (c) 1999,2000 Markus Friedl. All rights reserved.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
13 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
14 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
15 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
16 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
17 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
18 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
19 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
20 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
21 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
22 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 RCSID("$OpenBSD: compat.c,v 1.26 2000/10/26 18:38:28 markus Exp $");
33 # include <pcreposix.h>
34 #else /* Use native regex libraries */
36 #endif /* HAVE_LIBRX */
45 verbose("Enabling compatibility mode for protocol 2.0");
51 verbose("Enabling compatibility mode for protocol 1.3");
54 /* datafellows bug compatibility */
56 compat_datafellows(const char *version)
65 { "^OpenSSH-2\\.[01]", SSH_OLD_SESSIONID },
66 { "^OpenSSH_2\\.2", SSH_OLD_SESSIONID },
68 { "^2\\.1\\.0 ", SSH_BUG_SIGBLOB|SSH_BUG_HMAC|
70 { "^2\\.0\\.", SSH_BUG_SIGBLOB|SSH_BUG_HMAC|
72 SSH_BUG_PUBKEYAUTH|SSH_BUG_X11FWD },
73 { "^2\\.[23]\\.0 ", SSH_BUG_HMAC},
74 { "^2\\.[2-9]\\.", 0 },
75 { "^2\\.4$", SSH_OLD_SESSIONID}, /* Van Dyke */
76 { "^3\\.0 SecureCRT", SSH_OLD_SESSIONID},
77 { "^1\\.7 SecureFX", SSH_OLD_SESSIONID},
78 { "^2\\.", SSH_BUG_HMAC}, /* XXX fallback */
81 /* process table, return first match */
82 for (i = 0; check[i].pat; i++) {
83 ret = regcomp(®, check[i].pat, REG_EXTENDED|REG_NOSUB);
85 regerror(ret, ®, ebuf, sizeof(ebuf));
86 ebuf[sizeof(ebuf)-1] = '\0';
87 error("regerror: %s", ebuf);
90 ret = regexec(®, version, 0, NULL, 0);
93 debug("match: %s pat %s\n", version, check[i].pat);
94 datafellows = check[i].bugs;
98 debug("no match: %s", version);
103 proto_spec(const char *spec)
106 int ret = SSH_PROTO_UNKNOWN;
110 q = s = xstrdup(spec);
111 for ((p = strsep(&q, SEP)); p && *p != '\0'; (p = strsep(&q, SEP))) {
114 if (ret == SSH_PROTO_UNKNOWN)
115 ret |= SSH_PROTO_1_PREFERRED;
122 log("ignoring bad proto spec: '%s'.", p);