Damien Miller | 05e82c3 | 2014-05-15 14:33:43 +1000 | [diff] [blame] | 1 | /* $OpenBSD: bufbn.c,v 1.12 2014/04/30 05:29:56 djm Exp $ */ |
| 2 | |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 3 | /* |
Damien Miller | 05e82c3 | 2014-05-15 14:33:43 +1000 | [diff] [blame] | 4 | * Copyright (c) 2012 Damien Miller <djm@mindrot.org> |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 5 | * |
Damien Miller | 05e82c3 | 2014-05-15 14:33:43 +1000 | [diff] [blame] | 6 | * Permission to use, copy, modify, and distribute this software for any |
| 7 | * purpose with or without fee is hereby granted, provided that the above |
| 8 | * copyright notice and this permission notice appear in all copies. |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 9 | * |
Damien Miller | 05e82c3 | 2014-05-15 14:33:43 +1000 | [diff] [blame] | 10 | * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES |
| 11 | * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF |
| 12 | * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR |
| 13 | * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES |
| 14 | * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN |
| 15 | * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF |
| 16 | * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 17 | */ |
| 18 | |
Damien Miller | 05e82c3 | 2014-05-15 14:33:43 +1000 | [diff] [blame] | 19 | /* Emulation wrappers for legacy OpenSSH buffer API atop sshbuf */ |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 20 | |
Darren Tucker | 58538d7 | 2014-06-11 13:39:24 +1000 | [diff] [blame] | 21 | #include "includes.h" |
| 22 | |
Damien Miller | 72ef7c1 | 2015-01-15 02:21:31 +1100 | [diff] [blame] | 23 | #ifdef WITH_OPENSSL |
| 24 | |
Damien Miller | d783435 | 2006-08-05 12:39:39 +1000 | [diff] [blame] | 25 | #include <sys/types.h> |
| 26 | |
Damien Miller | d783435 | 2006-08-05 12:39:39 +1000 | [diff] [blame] | 27 | #include "buffer.h" |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 28 | #include "log.h" |
Damien Miller | 05e82c3 | 2014-05-15 14:33:43 +1000 | [diff] [blame] | 29 | #include "ssherr.h" |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 30 | |
Damien Miller | 72ef7c1 | 2015-01-15 02:21:31 +1100 | [diff] [blame] | 31 | #ifdef WITH_SSH1 |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 32 | int |
| 33 | buffer_put_bignum_ret(Buffer *buffer, const BIGNUM *value) |
| 34 | { |
Damien Miller | 05e82c3 | 2014-05-15 14:33:43 +1000 | [diff] [blame] | 35 | int ret; |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 36 | |
Damien Miller | 05e82c3 | 2014-05-15 14:33:43 +1000 | [diff] [blame] | 37 | if ((ret = sshbuf_put_bignum1(buffer, value)) != 0) { |
| 38 | error("%s: %s", __func__, ssh_err(ret)); |
| 39 | return -1; |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 40 | } |
Damien Miller | 05e82c3 | 2014-05-15 14:33:43 +1000 | [diff] [blame] | 41 | return 0; |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 42 | } |
| 43 | |
| 44 | void |
| 45 | buffer_put_bignum(Buffer *buffer, const BIGNUM *value) |
| 46 | { |
| 47 | if (buffer_put_bignum_ret(buffer, value) == -1) |
Damien Miller | 05e82c3 | 2014-05-15 14:33:43 +1000 | [diff] [blame] | 48 | fatal("%s: buffer error", __func__); |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 49 | } |
| 50 | |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 51 | int |
| 52 | buffer_get_bignum_ret(Buffer *buffer, BIGNUM *value) |
| 53 | { |
Damien Miller | 05e82c3 | 2014-05-15 14:33:43 +1000 | [diff] [blame] | 54 | int ret; |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 55 | |
Damien Miller | 05e82c3 | 2014-05-15 14:33:43 +1000 | [diff] [blame] | 56 | if ((ret = sshbuf_get_bignum1(buffer, value)) != 0) { |
| 57 | error("%s: %s", __func__, ssh_err(ret)); |
| 58 | return -1; |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 59 | } |
Damien Miller | 05e82c3 | 2014-05-15 14:33:43 +1000 | [diff] [blame] | 60 | return 0; |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 61 | } |
| 62 | |
| 63 | void |
| 64 | buffer_get_bignum(Buffer *buffer, BIGNUM *value) |
| 65 | { |
| 66 | if (buffer_get_bignum_ret(buffer, value) == -1) |
Damien Miller | 05e82c3 | 2014-05-15 14:33:43 +1000 | [diff] [blame] | 67 | fatal("%s: buffer error", __func__); |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 68 | } |
Damien Miller | 72ef7c1 | 2015-01-15 02:21:31 +1100 | [diff] [blame] | 69 | #endif /* WITH_SSH1 */ |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 70 | |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 71 | int |
| 72 | buffer_put_bignum2_ret(Buffer *buffer, const BIGNUM *value) |
| 73 | { |
Damien Miller | 05e82c3 | 2014-05-15 14:33:43 +1000 | [diff] [blame] | 74 | int ret; |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 75 | |
Damien Miller | 05e82c3 | 2014-05-15 14:33:43 +1000 | [diff] [blame] | 76 | if ((ret = sshbuf_put_bignum2(buffer, value)) != 0) { |
| 77 | error("%s: %s", __func__, ssh_err(ret)); |
| 78 | return -1; |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 79 | } |
Damien Miller | 05e82c3 | 2014-05-15 14:33:43 +1000 | [diff] [blame] | 80 | return 0; |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 81 | } |
| 82 | |
| 83 | void |
| 84 | buffer_put_bignum2(Buffer *buffer, const BIGNUM *value) |
| 85 | { |
| 86 | if (buffer_put_bignum2_ret(buffer, value) == -1) |
Damien Miller | 05e82c3 | 2014-05-15 14:33:43 +1000 | [diff] [blame] | 87 | fatal("%s: buffer error", __func__); |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 88 | } |
| 89 | |
| 90 | int |
| 91 | buffer_get_bignum2_ret(Buffer *buffer, BIGNUM *value) |
| 92 | { |
Damien Miller | 05e82c3 | 2014-05-15 14:33:43 +1000 | [diff] [blame] | 93 | int ret; |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 94 | |
Damien Miller | 05e82c3 | 2014-05-15 14:33:43 +1000 | [diff] [blame] | 95 | if ((ret = sshbuf_get_bignum2(buffer, value)) != 0) { |
| 96 | error("%s: %s", __func__, ssh_err(ret)); |
| 97 | return -1; |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 98 | } |
Damien Miller | 05e82c3 | 2014-05-15 14:33:43 +1000 | [diff] [blame] | 99 | return 0; |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 100 | } |
| 101 | |
| 102 | void |
| 103 | buffer_get_bignum2(Buffer *buffer, BIGNUM *value) |
| 104 | { |
| 105 | if (buffer_get_bignum2_ret(buffer, value) == -1) |
Damien Miller | 05e82c3 | 2014-05-15 14:33:43 +1000 | [diff] [blame] | 106 | fatal("%s: buffer error", __func__); |
Damien Miller | 58629fa | 2006-04-23 12:08:19 +1000 | [diff] [blame] | 107 | } |
Damien Miller | 72ef7c1 | 2015-01-15 02:21:31 +1100 | [diff] [blame] | 108 | |
| 109 | #endif /* WITH_OPENSSL */ |